学习笔记——C语言打印日志封装

简单的案例用于封装syslog,便于逻辑处理中直接使用

案例代码:

#include <stdio.h>
#include <syslog.h>

#define LOG(type, fmt, args...) syslog(type,"[%s:%s(%d)]:" fmt "\n", __FILE__,__FUNCTION__, __LINE__, ##args)

int main(int argc,char **argv){

    char info[20] = "message need printf";

    LOG(LOG_INFO,"info[%s]", info);
    /*等价于 syslog(LOG_INFO,"[%s:%s(%d)]:" "info[%s]" "\n", __FILE__, __FUNCTION__, __LINE__, j) */
    return 0;
}

编译,测试:

gcc test2.c -o test2
./test2

如果没有自定义syslog输出日志位置,则在/var/log/messages会有如下打印

Jun  8 18:59:45 localhost test2: [test2.c:main(11)]:info[message need printf]

至于日志输出的位置可以参考syslog相关配置文件syslog.conf

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值