1、需求
在Linux环境下用C编写一个函数,用于记录运行日志,要求只存在一个同名文件,每次记录前清除已有的信息。
2、思路
需要完成的是:
(1)查找(access)是否该文件存在,存在则删除,不存在则新建(fopen)。
(2)定位写入记录的位置(fseek)。
(3)写文件(fprintf)。
(4)刷新文件(fflush)。
(5)关闭文件退出(fclose)。
3、代码实现,采用数据流和标准库。
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>/*! Printf netting result in *.lni format */
static void PrintfLoRaNettingInfo(void)
{char *filename = "Info.lni";FILE *fd;char content[4096];int i;time_t timep;/*! check if exist */if(access(filename,F_OK) == 0){remove(filename);}/*! creat and opne */fd = fopen(filename,"a+");if(fd == NULL){printf("[ NET ]:open file error\n");return;}/*! table head */time (&timep);sprintf(content,"%s\n",asctime(localtime(&timep)));fprintf(fd,content);fseek(fd, 0, SEEK_END);sprintf(content,"nodeIdx addr isValid isConnected isRouted routeNodeIdx netLayer netQuality upSNR downSNR timecost\n");fseek(fd, 0, SEEK_END);fprintf(fd,content); for(i = 0; i < MAX_SLAVE_NODE; i++){sprintf(content,"%7d %8d %7d %11d %8d %12d %8d %10d %5d %7d %8d\n",i,*((uint32_t *)Slave.node[i].addr),Slave.node[i].isValid,Slave.node[i].isConnected,Slave.node[i].isRouted,Slave.node[i].routeNodeIdx,Slave.node[i].netLayer,Slave.node[i].netQuality,Slave.node[i].upSNR,Slave.node[i].downSNR,Slave.node[i].nettingTimeCost);fseek(fd, 0, SEEK_END);fprintf(fd,content);fflush(fd);}fclose(fd);printf("[ NET ]:Info.lni creat ok\n");
}