log日志文件的简单实现

/*****************************************************************************
    程序实现功能:

        读写一个文件,每隔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;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值