1, gcc中使用宏的例子:
#ifdef DEBUG
printf("Debug is define!\n");
#endif
printf("Hello World!\n");
希望在编译时,传递DEBUG定义,实现Debug版本和Release版本的区别。
gcc -DDEBUG -o ttt a.c b.c
gcc -o ttt a.c b.c
gcc -UDEBUG -o ttt a.c b.c 是取消宏定义
2, GNU Make
make是负责从项目的源代码中生成最终可执行文件和其他非源代码文件的工具。 make命令本身可带有四种参数:标志、宏定义、描述文件名和目标文件名。
其标准形式为:make [flags] [macro definitions] [targets]
Unix系统下标志位flags选项及其含义为:
-f file 指定file文件为描述文件,如果file参数为 '-' 符,那么描述文件指向标准输入。如果没有 '-f' 参数,则系统将默认当前目录下名为makefile或者名为Makefile的文件为描述文件。在Linux中, GNU make 工具在当前工作目录中按照GNUmakefile、makefile、Makefile的顺序搜索 makefile文件。
-i 忽略命令执行返回的出错信息。
-s 沉默模式,在执行之前不输出相应的命令行信息。
-r 禁止使用隐含规则。
-n 非执行模式,输出所有执行命令,但并不执行。
-t 更新目标文件。
-q make操作将根据目标文件是否已经更新返回"0"或非"0"的状态信息。
-p 输出所有宏定义和目标文件描述。
-d Debug模式,输出有关文件和检测时间的详细信息。
Linux下make标志位的常用选项与Unix系统中稍有不同,下面只列出了不同部分:
-c dir 在读取 makefile 之前改变到指定的目录dir。
-I dir 当包含其他 makefile文件时,利用该选项指定搜索目录。
-h help文挡,显示所有的make选项。
-w 在处理 makefile 之前和之后,都显示工作目录。
通过命令行参数中的target ,可指定make要编译的目标,并且允许同时定义编译多个目标,操作时按照从左向右的顺序依次编译target选项中指定的目标文件。如果命令行中没有指定目标,则系统默认target指向描述文件中第一个目标文件。
2.1 make macro definitions
makefile如下:
LIBES= -LS
# use macros rewrite makefile ..
prog: $(OBJECTS)
cc $(OBJECTS) $(LIBES) -o prog
此时假如执行不带参数的make命令,将连接三个目标文档和库文档LS;但是假如在make命令后带有新的宏定义:
make "LIBES= -LL -LS"
则命令行后面的宏定义将覆盖makefile文档中的宏定义。若LL也是库文档,此时make命令将连接三个目标文档连同两个库文档LS和LL。
make local_all "SW=SWM_DEBUG"
2.2 追加宏定义
c file:
#ifdef SWM_DEBUG
Tracker->Debug( "%s:%d:%s, none do iiiiiiiiiiiiiiiiiiiiiiiiiiiiiiiXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXxiiiiiiiiiiiiiiiiiiiiiii\n",__FILE__, __LINE__,__FUNCTION__ );
#endif
Makefile file:
CPPFLAGS += -DDEBUG_MEMORY
CPPFLAGS += -DDEBUG_CLASS_NAMES
make 命令:
make local_all "CPPFLAGS += -DSWM_DEBUG"
转自:http://hi.baidu.com/bamboolsu/blog/item/a30335d8d8ff512710df9b6f.html