c语言日志封装-输出文件名、函数名、行号
来源:互联网 发布:女性自慰姿势图解知乎 编辑:程序博客网 时间:2024/04/27 14:13
在后台程序运行出问题时,详尽的日志是抓错不可缺少的帮手,这里提供一个能自动记录日志触发点文件名、行号、函数名的方法,关键是利用C99新增的预处理标识符__VA_ARGS__
先介绍几个编译器内置的宏定义,这些宏定义不仅可以帮助我们完成跨平台的源码编写,灵活使用也可以巧妙地帮我们输出非常有用的调试信息。
ANSI C标准中有几个标准预定义宏(也是常用的):
__LINE__:在源代码中插入当前源代码行号;
__FILE__:在源文件中插入当前源文件名;
__DATE__:在源文件中插入当前的编译日期
__TIME__:在源文件中插入当前编译时间;
__STDC__:当要求程序严格遵循ANSI C标准时该标识被赋值为1;
__cplusplus:当编写C++程序时该标识符被定义。
代码:
- #define LOG(level, format, ...) /
- do { /
- fprintf(stderr, "[%s|%s@%s,%d] " format "/n", /
- level, __func__, __FILE__, __LINE__, ##__VA_ARGS__ ); /
- } while (0)
- int main()
- {
- LOG(LOG_DEBUG, "a=%d", 10);
- return 0;
- }
- 运行结果:
- [DEBUG|main@a.c,17] a=10
限制是format不能是变量,必须是常量字符串,如果要记录一个变量字符串,不能像printf那样printf(s)了,要LOG("DEBUG", "%s", s)。
另外还有一种:
- //============================================================================
- // Name : debug.cpp
- // Author : boyce
- // Version : 1.0
- // Copyright : pku
- // Description : Hello World in C++, Ansi-style
- //============================================================================
- #include <stdio.h>
- #define __DEBUG__
- #ifdef __DEBUG__
- #define DEBUG(format,...) printf("File: "__FILE__", Line: %05d: "format"\n", __LINE__, ##__VA_ARGS__)
- #else
- #define DEBUG(format,...)
- #endif
- int main(int argc, char **argv) {
- char str[]="Hello World";
- DEBUG("A ha, check me: %s",str);
- return 0;
- }
转自:http://blog.csdn.net/shanzhizi/article/details/8983768
阅读全文
0 0
- c语言日志封装-输出文件名、函数名、行号
- C语言实现日志封装--能输出调用函数、文件名、行号
- c语言输出文件名函数名和行号
- C语言 打印文件名,行号,函数名
- C++输出文件名、函数名、行号
- 程序日志中自动记录所在函数名、文件名、行号,并定向输出到一个日志文件
- 日志中自动记录所在函数名、文件名、行号
- c#输出文件名、行号、函数名、列号
- C/C++语言中如何使用宏打印行号、文件名和函数名
- C/C++ 打印文件名、行号、函数名的方法
- C/C++ 打印文件名、行号、函数名的方法 .
- C/C++ 打印文件名、行号、函数名的方法
- Swift - 实现日志输出的封装1(显示出调用的文件名、方法、行号)
- 显示当前行号、文件名和函数名
- python 获取当前行号 函数名 文件名
- Java打印文件名、函数名、行号
- Android 打印文件名、函数名、行号
- printf 打印 文件名 函数名 行号
- 对 cas 操作的理解
- zookeeper 删除日志文件任务
- 搭建直播记录
- Android6.0以上版本去除应用权限
- 受限玻尔兹曼机基础教程
- c语言日志封装-输出文件名、函数名、行号
- SQL循环拆分
- python3-列表练习
- 通过webSocket实现app运动数据在网页实时显示
- 聊聊极简风格的过去与现在
- 日常操作命令
- MTK Android 5.0以上版本的变化
- 快速排序PYTHON
- Meet Surprise让你展现自己的美