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");
}

4、效果

Logo

更多推荐