编写程序时, 经常需要划分级别, 如 Debug 级别,release级别等。可以分开一些日志等信息是否必要。
例如:
#ifdef _DEBUG_
#define DEBUG_LOG printf
#else
#define DEBUG_LOG
#endif
意思就是, 如果定义了 _DEBUG_ 就 将系统中的 DEBUG_LOG 语句换成 printf,就是执行打印的意思。
如果没有定义, 就什么也不做。
我们可以在程序开头加上 #define _DEBUG_
或者
在gcc编译的时候加上选项 gcc -D_DEBUG_ -o 123 -g test.cpp
这样程序就知道, 什么时候 该打印, 什么时候不打印了。
说明:
#define _DEBUG_ 后面可以什么都不写哦! 表示 仅定义,不做任何从命名工作
还有另外一种 更简单的方式,
源码:
#include <stdio.h>
int main()
{
DEBUG_LOG("HELLO WORLD\n");
return 0;
}
g++ -o tmp -g test.cpp -DDEBUG_LOG=printf
此问题 在于 此-DDEBUG_LOG 必须被定义,否则编译器会报错。
说明: 此处 -D 选项后 的空格 可有可无。
宏“DEBUG_LOG” 后的 等号及其后数据 是可选择的。