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;
}
程序实现功能:
读写一个文件,每隔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;
}
相关文章推荐
- EventBus的简单实现与log日志的使用
- Ubuntu14.04实现简单日志文件服务器
- C# 实现一个Log日志文件 以每2Mb创建一个新的日志
- MSSQL2005单一MDF文件的还原-简单语句实现attach_force_rebuild_log
- C# 实现一个Log日志文件 以每2Mb创建一个新的日志
- microlog4android将Android Log日志写到SD卡文件中实现方法
- 使用触发器实现记录oracle用户登录失败信息到alert.log日志文件
- libevent基础文件log.c(日志实现)
- shell脚本实现:每周 5 使用 tar 命令备份/var/log 下的所有日志文件
- c++程序中写测试log到文件的简单实现
- PHP简单实现定时监控nginx日志文件功能示例
- SDL游戏开发教程06(利用BOOST库实现简单的文件日志功能)
- 最简单的基于VC的日志文件类库实现
- 从Apache的日志文件收集和提供统计数据(一个Python插件架构的简单实现)
- 自行控制loadrunner的socket协议性能测试 (转) 一前言 二任务的提出 三实现方案讨论 四技术要点讲解 如何开始录制一个最简单的收发数据包脚本 写日志文件 一行一行读数据包文件 字
- 简单实现:如何把所有的日志记录到同一个文件中???
- Android编程实现项目中异常捕获及对应Log日志文件保存功能
- Qt中简单的日志文件实现
- PHP实现简单的监控nginx日志文件功能
- Ajax简单实现文件异步上传的多种方法