您的位置:首页 > 其它

log日志文件的简单实现

2013-07-05 20:36 621 查看
/*****************************************************************************

程序实现功能:

读写一个文件,每隔1秒向文件中写入一行数据,类似以下格式

1, 2001-5-23 12:32:45

2, 2001-5-23 12:32:46

该程序无限循环,直到人为中断

再次启动程序写文件时可以追加到原文件之后,并且序号能够接续上次的序号

******************************************************************************/

#include <stdio.h>

#include <string.h>

#include <errno.h>

#include <time.h>

#include <unistd.h> //sleep()函数的头文件

int main(int argc, char *argv[])

{

FILE *fp;

time_t time_sec; //保存从1970年至今的秒数

struct tm * date; //将time_sec转换成具体的时间,保存在tm类型的结构体里

int line = 0; //统计文件的行数

int ch;

if (argc < 2)

{

printf("usage:%s file\n", argv[1]);

return -1;

}

if ((fp = fopen(argv[1], "a+")) == NULL)

{

perror("open");

return -1;

}

if (fseek(fp, 0, SEEK_SET) != 0) //定位到文件开头

{

perror("fseek");

return -1;

}

while ((ch=fgetc(fp)) != EOF) //统计行数

{

if (ch == '\n')

line++;

}

fseek(fp, 0, SEEK_END); //定位到文件末尾

while (1)

{

if (time(&time_sec) == -1) //将1970年至今的秒数保存在time_sec中

{

perror("time");

return -1;

}

date = localtime(&timet); //将time_sec保存到date的结构体中 man localtime

fprintf(fp, "%d, %d-%d-%d %d:%d:%d\n", ++line, date->tm_year+1900, date->tm_mon+1,

date->tm_mday, date->tm_hour, date->tm_min, date->tm_sec);

fflush(fp); //刷新缓冲区

sleep(1);

}

return 0;

}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: