使用预处理进行程序调试

预备知识:

1.程序所包含的调试代码仅在开发过程中执行,当应用程序已经完成,并且准备提交时,就会将调试代码关闭。可使用NDEBUG预处理变量实现有条件的调试代码;

2.gcc/g++编译器提供定义NDEBUG的命令行选项:

    $ g++ -NDEBUG ./debug_test.cpp

   类似这样的命令行等效于在debug_test.cpp文件的开头提供了#define NDEBUG预处理命令。

3.预处理器定义了四种在调试时非常有用的常量:

  __FILE__ 文件名

 __LINE__ 当前行号

__TIME__ 文件被编译的时间

__DATE__文件被编译的日期

4.另一个常见的调试技术是使用NDEBUG预处理变量以及assert预处理宏。assert宏需要一个表达式作为它的条件:

    assert (expr)

  只要NDEBUG未定义,assert宏就求解条件表达式expr,如果结果为false,assert输出信息并且终止程序的执行。如果该表达式有一个非零(例如:true)值,则assert不做任何操作。


以下通过一个程序来说明。


程序清单:

 

编译源程序:

        g++ -o  debug_test debug_test.cpp

运行程序:

        ./debug_test

执行结果:

 Starting main function...

Please input a word:love

Error: debug_test.cpp: line 20

           Compiled on Dec 12 2010 at 22:00:16

           Word read was  "love": Length too short


如果在编译的时候加上选项"--DNDEBUG"调试:

 

 g++ -o debug_test -DNDEBUG debug_test.cpp

运行程序:

 ./debug_test

运行结果:

Please input a word:Love

Error: debug_test.cpp: line 20

          Compiled on Dec 12 2010 at 22:19:50

          Word read was  "Love": Length too short


 


 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值