博客专栏

EEPW首页 > 博客 > Makefile 宏定义 -D

Makefile 宏定义 -D

发布人:电子禅石 时间:2021-01-08 来源:工程师 发布文章

一、GCC编译器中使用:
        -D macro=string,等价于在头文件中定义:#define   macro   string。

    例如:-D TRUE=true,等价于:#define   TRUE   true
        -D macro,等价于在头文件中定义:#define   macro   1,实际上也达到了定义:#define   macro的目的。

    例如:-D Linux,等价于:#define   LINUX   1(与#define   LINUX作用类似)。
        --define-macro   macro=string与-D macro=string作用相同。

 

如:TEST.C 文件

复制代码
#include <stdio.h>#include <stdlib.h>main()
{
#ifdef p1
  printf("Hello p1");#else
  printf("Hello p2");#endif
 }
复制代码

 

1.编译: gcc -o test test.c

运行: ./test

输出: Hello p2

2.编译: gcc -o test test.c -D p1

运行: ./test

输出: Hello p1

 

二、Makefile中进行宏定义-D

在Makefile中我们可以通过宏定义来控制源程序的编译。只要在Makefile中的CFLAGS中通过选项-D来指定你于定义的宏即可。

如:
CFLAGS += -D _YUQIANG

在编译的时候加上此选项就可以了: $(CC) $(CFLAGS) $^ -o $@ 

 

DEFINES +=  -D BVS_DIRECTION=$(BVS_DIRECTION) \            -D BVS_LAYOUT=$(BVS_LAYOUT) \            -D $(BVS_TYPE)\

 


*博客内容为网友个人发布,仅代表博主个人观点,如有侵权请联系工作人员删除。



关键词:

相关推荐

技术专区

关闭