如何在工程设置中添加宏定义?

如何在工程设置中添加宏定义?,第1张

iphone

sdk从2.2开始就不能很方便的加入预处理宏了

2.2之后的方法是在gcc编译选项组下面,手工添加一个字段gcc_preprocessor_definitions,然后对应的value填上你的预处理define即可

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) $(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

如果你有读过 C语言标准的话,C 语言有三个比较大的版本 C89/99/11

fopen_s 是属于 C11 的新内容,首先要你的编译器支持 C11

【编译器是否支持C11】

这个可以通过预定义宏(__STDC_VERSION__)判断,也就是

#if __STDC_VERSION__ >= 201112L

或者 if(__STDC_VERSION__ >= 201112L)

如果是支持 C11 的编译器会返回 true

【编译器是否支持 Annex K】

然后在支持 C11 条件下,编译器可以选择是否支持 Annex K ( 附录K )

( 支持附录K,意味着支持 fopen_s 这些函数 )

判断编译器是否支持 Annex K,只需要判断预定义宏(__STDC_LIB_EXT1__),也就是

#if __STDC_LIB_EXT1__ >= 201112L

或者 if(__STDC_LIB_EXT1__ >= 201112L)

如果是支持 Annex K 的编译器会返回 true

【向编译器请求启用 Annex K 下的安全函数使用】

#define __STDC_WANT_LIB_EXT1__ 1

#include <stdio.h>

在导入<stdio.h>之前,定义宏 __STDC_WANT_LIB_EXT1__ 的值为 1

恭喜你启用了 printf_s scanf_s fopen_s 这些安全函数

【此方法不一定都适用】

这个方法仅适用于那些按照C语言标准的编译器,mingw64编译器我没用过,

只知道像 vs 就默认启用 scanf_s,如果以上方法不行,具体编译器要查具体规则


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11364262.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-15
下一篇 2023-05-15

发表评论

登录后才能评论

评论列表(0条)

保存