Makefile,如何传递宏定义DEBUG【转】

简介:

转自:http://blog.csdn.net/linuxheik/article/details/8051598

Makefile,如何传递宏定义DEBUG


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)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"

 

 

 

 

 

相关文章
|
Linux Windows
Linux tar/rpm/yum命令软件安装
Linux tar/rpm/yum命令软件安装
809 2
|
Java
SpringBoot 使用 private final 注入Bean
SpringBoot 使用 private final 注入Bean
1385 0
SpringBoot 使用 private final 注入Bean
|
Linux API 调度
重温Linux内核:互斥和同步
本文全面回顾了Linux内核中的互斥和同步机制,包括中断屏蔽、原子变量、自旋锁、读写锁、顺序锁、信号量、互斥量、RCU机制以及完成量等,提供了它们的定义、实现原理、API用法和使用时的注意事项。
203 0
|
存储 C++
【C++】Visual Studio C++ 配置并使用gtest(不好用你捶我)
【C++】Visual Studio C++ 配置并使用gtest(不好用你捶我)
|
监控 项目管理
精益求精:ERP系统的项目管理与团队协作
精益求精:ERP系统的项目管理与团队协作
541 0
|
存储 运维 Cloud Native
Curve 块存储实践 _ 十分钟带你体验高性能云原生数据库PolarDB
Curve 块存储是云原生计算基金会 (CNCF) Sandbox 项目,是网易自研和开源的高性能、易运维、云原生的分布式存储系统。而 PolarDB File System (PFS)是由阿里云自主研发的高性能类 POSIX 的用户态分布式文件系统,服务于阿里云数据库 PolarDB 产品。通过本文的介绍,大家可以快速部署一套 PolarDB+PFS+CurveBS 的云原生数据库,并在 PFS 上编译部署 PolarDB 。
|
存储 Linux 内存技术
ramfs和ramdisk文件系统的制作和启动
ramfs和ramdisk文件系统的制作和启动
|
Web App开发
Chrome 无法抓取跳转请求的解决办法
Chrome 无法抓取跳转请求的解决办法
360 0
|
NoSQL 应用服务中间件 Redis
Filebeat限制采集的日志大小实际应用验证
Filebeat限制采集的日志大小实际应用验证
323 0