• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

__FILE____LINE__C++宏定义调试

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

参考博文:http://www.cnblogs.com/lixiaohui-ambition/archive/2012/08/21/2649052.html

自定义宏定义,来控制printf输出调试信息。

  1)使用可变参数的宏  ##__VA_ARGS__  来对应printf的多参数。(注意:其中 __  为2个连续的”_“)

  2) 使用编译器内置的宏  __FILE__    __LINE__ 来输出代码所在文件名及行号(注意:其中 __  为2个连续的”_“)

代码示例如下:

//================================================
// Name : debug.cpp
// Author : vin
// Version : 1.0
// Description : Hello World in C++, Ansi-style
//================================================

#include <stdio.h>
#include <stdlib.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()
{
    char str[] = "Hello World";
    DEBUG("A ha,check me :%s", str);
   // printf("hello\n");
    system("pause");
    return 0;
}

在代码调试阶段,保留 ”#define _DEBUG_“;在发布时,直接注释掉该宏,则不会输出调试信息,非常方便。


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
队列的定义与实现(C语言实现)发布时间:2022-07-14
下一篇:
深入C++03:面向对象发布时间:2022-07-14
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap