博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
linux 调试 之printf
阅读量:6233 次
发布时间:2019-06-22

本文共 1608 字,大约阅读时间需要 5 分钟。

1. 可变参数宏

1.1 C99 标准中可变参数宏

#define debug(format, ...) printf(format, ##__VA_ARGS__)

1.2 gcc 复杂宏

#define debug(format, args...) printf(format, ##args)

#的作用 : 连接两个宏,如果可变参数被忽略或为空,"##"操作将使预处理器(preprocessor)去除掉它前面的那个逗号.

2. 打印带颜色的字符串

2.1 格式

printf("\033[字背景颜色;字体颜色m字符串\033[0m" );

2.2 颜色码

背景色                           前景色40: 黑                           30: 黑41: 红                           31: 红42: 绿                           32: 绿43: 黄                           33: 黄44: 蓝                           34: 蓝45: 紫                           35: 紫46: 深绿                         36: 深绿47: 白色                         37: 白色

3. 举例----打印调试宏

#ifndef __USE_DEBUG                                                                                                                   #define __USE_DEBUG#ifdef  USE_DEBUG#define DEBUG_LINE() printf("[%s:%s] line=%d\r\n",__FILE__, __func__, __LINE__)#define DEBUG_ERR(fmt, args...) printf("\033[47;31m[%s:%d]\033[0m   "fmt" \r\n", __func__, __LINE__,  ##args)#define DEBUG_INFO(fmt, args...) printf("\033[33m[%s:%d]\033[0m  "fmt"  \r\n", __func__, __LINE__, ##args)#else#define DEBUG_LINE()#define DEBUG_ERR(fmt, ...)#define DEBUG_INFO(fmt, ...)#endif#endifint main(int args, const char ** argv){    int fd;        fd = open("/dev/nothing, O_RDWR");    if(fd < 0){        DEBUG_ERR(“open failed, ret = %d, %m\n”, fd);    }}

运行:

linux@fyang:~/work/debug$ gcc debug.c -DUSE_DEBUG

linux@fyang:~/work/debug$ ./a.out
[main:42] open faild, ret = -1, No such file or directory
linux@fyang:~/work/debug$

注: %m 会打印errno 对应的字符串 功能类似 perror

转载于:https://www.cnblogs.com/fengyang66/p/6523329.html

你可能感兴趣的文章
如何rename datafile name中存在乱码的数据文件
查看>>
Oracle Sun Exadata V2 ,X2-2,X2-8 主要配置对比
查看>>
制造业如何将工人师傅的隐性技能转化为显性知识?
查看>>
JXplorer 的简单使用
查看>>
__name__ == "__main__"
查看>>
编译安装nginx1.10.2最新版、php7.0.12最新版、mysql5.7.16最新版
查看>>
希尔排序(Golang)
查看>>
修改grub背景图
查看>>
netapp日志中hw_assist: hw_assist functionality is inactive.排错
查看>>
SaltStack实战之配置管理-状态间关系
查看>>
sc 与net命令的区别
查看>>
2018年区块链五大关键趋势预测:区块链与物联网结合有望突破
查看>>
delphi webservices传数据
查看>>
CentOS7离线安装docker问题解决
查看>>
moss 2007内容类型,如文档库设定新建xx菜单
查看>>
saltstack设置minion分组
查看>>
汇编和反汇编的区别
查看>>
ESXI主机网络负载均衡(基于portID,MAC,IP HASH)
查看>>
把视图查询权限授予普通用户
查看>>
json相关
查看>>