C学习笔记-C语言传入类似printf()参数形式

//简单记录错误日志,生成log文件
//函数
int type = 1;
int length = 10;

logs("rtcm3 %d length error: len=%d\n", type,length );//类似printf()函数参数

//生成log文件如下

//实现函数
void logs(const char *format,...)
{
    va_list va;
    va_start(va, format);
    char buf[1024];//接收
    memset(buf, 0, 1024);
    (void)vsprintf_s(buf,1024, format, va);
    SYSTEMTIME ts; //获取时间
    GetSystemTime(&ts); /* utc */
    FILE *logFile; //存储文件
    fopen_s(&logFile, "rtcm.log", "a");
    fprintf(logFile, "%d %d %d %d %d %lf:", ts.wYear, ts.wMonth, ts.wDay, ts.wHour, ts.wMinute, ts.wSecond + round(ts.wMilliseconds*1E-3));
    fprintf(logFile, "%s\n", buf); //将传入的字符串与系统时间拼接
    fclose(logFile);
    va_end(va);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值