linux下C语言实现写日志功能
发表于:2025-02-06 作者:千家信息网编辑
千家信息网最后更新 2025年02月06日,先上程序,该程序经过测试能够很好的实现写日志要求/*************************************************************************
千家信息网最后更新 2025年02月06日linux下C语言实现写日志功能
先上程序,该程序经过测试能够很好的实现写日志要求
/************************************************************************* > File Name: log.c > Author: ************************************************************************/#include#include #include #include #include #include #include #include #include int safe_asprintf(char **strp, const char *fmt, ...);int safe_vasprintf(char **strp, const char *fmt, va_list ap);void plog(const char *format, ...) ;void pinfo(const char *format, ...) ;#define DEBUG#ifdef DEBUGvoid plog(const char *format, ...);void pinfo(const char *format, ...);#define debug(fmt, args...) plog(fmt, ##args) #else#define debug(fmt, args...) do{}while(0)#endifstatic pthread_mutex_t fileMutex = PTHREAD_MUTEX_INITIALIZER;int main(int argc, char *argv){ return 0;}/* * safe_asprintf(); */int safe_asprintf(char **strp, const char *fmt, ...) { va_list ap; int retval; va_start(ap, fmt); retval = safe_vasprintf(strp, fmt, ap); va_end(ap); return retval;}/* * safe_vasprintf(); */int safe_vasprintf(char **strp, const char *fmt, va_list ap) { int retval; retval = vasprintf(strp, fmt, ap); if (retval == -1) { printf("Failed to vasprintf: %s. Bailing out\n", strerror(errno)); return 1; } return retval;}/* * plog(); */void plog(const char *format, ...) { pthread_mutex_lock(&fileMutex); FILE *fp = NULL; va_list vlist; char *fmt = NULL; // Open debug info output file. if (!(fp = fopen("log.txt", "a+"))) { pthread_mutex_unlock(&fileMutex); return; } va_start(vlist, format); safe_vasprintf(&fmt, format, vlist); va_end(vlist); if (!fmt) { pthread_mutex_unlock(&fileMutex); return; } time_t timep; struct tm *ptm = NULL; time(&timep); ptm = localtime(&timep); fprintf(fp, "[d-d-d-d-d-d] %s", ptm->tm_year + 1900, ptm->tm_mon + 1, ptm->tm_mday, ptm->tm_hour, ptm->tm_min, ptm->tm_sec, fmt); free(fmt); fsync(fileno(fp)); fclose(fp); pthread_mutex_unlock(&fileMutex);}/* * pinfo(); */void pinfo(const char *format, ...) { pthread_mutex_lock(&fileMutex); FILE *fp = NULL; va_list vlist; char *fmt = NULL; // Open debug info output file. if (!(fp = fopen("log.txt", "a+"))) { pthread_mutex_unlock(&fileMutex); return; } va_start(vlist, format); safe_vasprintf(&fmt, format, vlist); va_end(vlist); if (!fmt) { pthread_mutex_unlock(&fileMutex); return; } fprintf(fp, "%s", fmt); free(fmt); fsync(fileno(fp)); fclose(fp); pthread_mutex_unlock(&fileMutex);}
程序实现的日志格式为:
时间 + 空格 + 具体实现(自己的调试内容)
本段程序值得学习的地方:
- va_list 结构体的使用
- linux 的格式化输出字符串
- 文件操作过程中pthread_mutex锁的使用,以及他的优点
- linux DEBUG 的应用,方便调试
linux如何查看日志:
使用tail 命令可以实现日志的查询,以及其他功能,不了解的话,自行查资料解决。
对上面应用不明白的请自行查资料解决。
日志
程序
格式
资料
应用
功能
优点
内容
命令
地方
字符
字符串
文件
时间
空格
结构
过程
学习
查询
测试
数据库的安全要保护哪些东西
数据库安全各自的含义是什么
生产安全数据库录入
数据库的安全性及管理
数据库安全策略包含哪些
海淀数据库安全审计系统
建立农村房屋安全信息数据库
易用的数据库客户端支持安全管理
连接数据库失败ssl安全错误
数据库的锁怎样保障安全
数据库中所有列使用汉字标题
数据库菜单设计图片
公司实用软件开发完整流程
同花顺正在切换服务器连接失败
交互式绘图软件开发
本地服务器 管理员权限设置
部落守卫战服务器
软件数据库更新和缓存
小学生网络安全竟赛
局域网git服务器
服务器电源防护措施
csgo服务器为什么老炸
生产服务器风扇
服务器安全狗是什么情况
票据之星的数据库
网络安全协会副理事长 赵
计算机网络技术专业格证书
亿速运服务器怎么登录
网络安全和推荐算法
海南金邦互联网科技
xbox商店无法连接服务器
网络安全手绘教学
为什么要宣传网络安全
广西服务器机柜价格
手机版网易mc生存服务器推荐
炸了我的世界服务器会怎么样
小学生网络安全竟赛
网络安全文章小学生
上海点和网络技术有限公司
网络安全和推荐算法