当前位置: 首页 > news >正文

linux 调试 之printf

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

#endif




int 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

相关文章:

  • 普通函数和构造函数的区别
  • jwplayer 隐藏属性方法记载
  • hadoop2.7.3 HA高可用集群安装
  • lcx转发
  • 分布式数据库
  • github指令
  • Mysql 死锁
  • Centos Svn 仓库部署
  • 编码规范
  • Java数据结构之Set学习总结
  • 调用PostgreSQL存储过程,找不到函数名的问题
  • CAP理论
  • HDU 2501 Tiling_easy version
  • 透明代理Transparent Proxy
  • linux 配置软连接的需要注意的一个问题
  • 【399天】跃迁之路——程序员高效学习方法论探索系列(实验阶段156-2018.03.11)...
  • 0基础学习移动端适配
  • 2017-09-12 前端日报
  • CSS魔法堂:Absolute Positioning就这个样
  • ES6语法详解(一)
  • HashMap ConcurrentHashMap
  • JavaScript设计模式系列一:工厂模式
  • js学习笔记
  • Netty 4.1 源代码学习:线程模型
  • nginx(二):进阶配置介绍--rewrite用法,压缩,https虚拟主机等
  • PHP的类修饰符与访问修饰符
  • Spring技术内幕笔记(2):Spring MVC 与 Web
  • uva 10370 Above Average
  • 官方新出的 Kotlin 扩展库 KTX,到底帮你干了什么?
  • 来,膜拜下android roadmap,强大的执行力
  • 模仿 Go Sort 排序接口实现的自定义排序
  • 三栏布局总结
  • 微信端页面使用-webkit-box和绝对定位时,元素上移的问题
  • 微信小程序设置上一页数据
  • 无服务器化是企业 IT 架构的未来吗?
  • ​520就是要宠粉,你的心头书我买单
  • ​LeetCode解法汇总2304. 网格中的最小路径代价
  • ​Linux·i2c驱动架构​
  • #考研#计算机文化知识1(局域网及网络互联)
  • #我与Java虚拟机的故事#连载17:我的Java技术水平有了一个本质的提升
  • (2)(2.10) LTM telemetry
  • (4)事件处理——(6)给.ready()回调函数传递一个参数(Passing an argument to the .ready() callback)...
  • (ZT)薛涌:谈贫说富
  • (备忘)Java Map 遍历
  • (附源码)python房屋租赁管理系统 毕业设计 745613
  • (企业 / 公司项目)前端使用pingyin-pro将汉字转成拼音
  • (三分钟了解debug)SLAM研究方向-Debug总结
  • (一)使用IDEA创建Maven项目和Maven使用入门(配图详解)
  • (原創) 博客園正式支援VHDL語法著色功能 (SOC) (VHDL)
  • .net core 6 集成 elasticsearch 并 使用分词器
  • .Net core 6.0 升8.0
  • .Net MVC + EF搭建学生管理系统
  • .NET 设计一套高性能的弱事件机制
  • .NET中两种OCR方式对比
  • .w文件怎么转成html文件,使用pandoc进行Word与Markdown文件转化