Makefile中宏定義


實際上是gcc命令支持-D宏定義,相當於C中的全局#define:

gcc -D name
gcc -D name=definition
Makefile中可以定義變量(和宏很像),但是是給make解釋器用的,對所編譯的文件完全沒有作用。
 
MSTAR:宏定義方式:字串定義方式和值定義方式
CC_TVOPTS += -DMS_BOARD_TYPE_SEL=$(BOARD_TYPE_SEL)
CC_TVOPTS += -DMS_SW_CUS_SEL=SW_CONFIG_TRUNK_ATVMM
CC_TVOPTS += -DENABLE_CAPE=0 
CC_TVOPTS += -DMS_SW_TEST=\"VIDEOCON.BIN\"
CC_TVOPTS += -DMS_SW_TEST=\"${MEGENAME}\"
關鍵詞: Make宏定義 Make傳遞宏定義 Makefile中添加宏定義 Makefile -D

在Makefile中我們可以通過宏定義來控制源程序的編譯。只要在Makefile中的CFLAGS中通過選項-D來指定你於定義的宏即可。

如:
CFLAGS += -D _SAYHELLO
在編譯的時候加上此選項就可以了: $(CC) $(CFLAGS) $^ -o $@ 
下面是我寫的一個測試文件:

例如:

Makefile文件內容為:

CC = gcc
RM = rm

CFLAGS += -D _SAYHELLO

TARGETS := myapp

all:$(TARGETS)

$(TARGETS):main.c
$(CC) $(CFLAGS) $^ -o $@

clean:
-$(RM) -f *.o
-$(RM) -f $(TARGETS)

 

main.c文件的內容為:
#include <stdio.h>

int main()
{

  #ifdef _SAYHELLO
    printf("Hello , How are you?\n");
  #else
    printf("Sorry to lost you. \n");
  #endif

  return 0;
}

  


在端口中輸入    make clean all
然后輸入           ./myapp

結果                  Hello , How are you?


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM