c语言实现一个日志系统,记录程序运行状态,提供可维可测手段!

1. 使用日志的必要性

在一个正式的项目中,设计一个日志系统是很有必要的。当程序执行不符合预期,一个日志有助于我们分析程序运行的状态,进而定位到异常点。

使用日志的好处

1.日志不同于我们借助开发工具调试程序,在一个庞大的系统中,借助开发工具调试程序仅限于程序开发调试阶段,其他阶段使用都是不恰当的。
2.日志开关可以在平常程序运行时打开,一旦遇到问题时,就能够通过LOG对问题进行分析。避免出现低概率问题出现后难以复现、难以定位的情况。
3.因日志系统需要IO操作,对系统性能是有影响的。在程序运行稳定时,可以通过功能开关把日志关闭。

2.设计一个日志系统的考虑

设计一个日志系统,应该从下面几点进行考虑:

1.日志函数是对外提供接口供调用?会不会有多处调用,同时写文件?如何解决IO一致问题
2.通过一个单独的线程来处理写日志?
3.日志中,应该保存哪些信息?
4.运行过程中,日志文件会不断增大。日志文件大小如何设置?
5.如何兼顾性能?日志文件要有相应的宏开关

3. 代码

下述代码,提供把程序运行状态信息打印到控制台,并保存在本地文件中。

#include <stdio.h>  
#include <stdlib.h>  
#include <stdarg.h>  
#include <time.h>  
  
// 日志级别定义  
typedef enum {
   
     
    LOG_VERBOSE,  
    LOG_DEBUG,  
    LOG_INFO,  
    LOG_WARN,  
    LOG_ERROR  
} LogLevel;  
  
// 日志级别对应的字符串  
const char* logLevelStrings[] = {
   
     
    "VERBOSE",  
    "DEBUG",  
    "INFO",  
    "WARN",  
    "ERROR"  
};  
  
// 当前日志级别,可以动态调整  
LogLevel currentLogLevel = LOG_INFO;  
  
// 日志文件指针  
FILE* logFile = NULL;  
  
// 打开日志文件  
void openLogFile
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

同志仍需努力!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值