Makefile中的CFLAGS、$^、$< 、$@
1.CFLAGS
CFLAGS是一個在C編譯過程中使用的變量,它定義了編譯器的選項和標志。在編寫Makefile文件時,CFLAGS可以用來指定編譯器需要的編譯選項。
CFLAGS變量通常用于設置編譯器的一些選項,例如:
調試信息選項:-g
優(yōu)化選項:-O
編譯警告選項:-Wall
指定包含目錄選項:-I
指定庫目錄選項:-L
指定庫文件選項:-l
等等
例如,以下是一個使用CFLAGS變量的Makefile示例:
CC = gcc CFLAGS = -Wall -I./include -L./lib -lmylibmyapp: main.o foo.o bar.o$(CC) $(CFLAGS) $^ -o $@main.o: main.c$(CC) $(CFLAGS) -c $< -o $@foo.o: foo.c$(CC) $(CFLAGS) -c $< -o $@bar.o: bar.c$(CC) $(CFLAGS) -c $< -o $@clean:rm -f myapp *.o在上述示例中,CFLAGS變量包含了-Wall選項用于開啟所有警告信息、-I./include選項用于指定頭文件的搜索路徑、-L./lib和-lmylib選項用于鏈接名為libmylib的庫文件。
在編譯myapp目標時,Makefile使用了$(CFLAGS)變量來指定編譯選項,而不需要在每個編譯命令中都指定一遍。
2.$^
在Makefile中,$^表示所有的依賴文件列表,也就是指當前規(guī)則所依賴的所有文件,以空格分隔。在一個規(guī)則中,如果有多個依賴文件,可以使用$^來表示所有的依賴文件,這樣可以簡化Makefile的編寫。
例如,假設有如下的Makefile規(guī)則:
target: dep1 dep2 dep3command其中,target表示目標文件,dep1、dep2、dep3表示依賴文件,command表示編譯命令。如果我們使用$^來表示所有的依賴文件,那么上面的規(guī)則可以寫成如下形式:
target: dep1 dep2 dep3command $^在這個例子中,$^表示所有的依賴文件dep1、dep2、dep3,編譯命令可以使用$^來自動展開所有的依賴文件列表。
3.$<
在Makefile中,$<是一個自動化變量,表示依賴項中的第一個文件名。
在一個規(guī)則中,依賴項通常是由規(guī)則的第二個及之后的目標定義的,例如:
main.o: main.c foo.h bar.hgcc -c $<在上面的例子中,$<代表依賴項中的第一個文件"main.c"。在執(zhí)行這個規(guī)則時,Make會首先檢查"main.c"是否有更新,然后如果需要的話會重新編譯它,并將生成的目標文件"main.o"放在當前目錄下。
4.$@
在Makefile中,$@是一個自動化變量,表示目標文件的名稱。
在一個規(guī)則中,目標文件通常是由規(guī)則的第一個目標定義的,例如:
main: main.o foo.o bar.ogcc -o $@ $^在上面的例子中,$@代表目標文件"main"。在執(zhí)行這個規(guī)則時,Make將把所有依賴項"main.o"、"foo.o"和"bar.o"編譯成目標文件"main"。然后,Make會執(zhí)行命令:
gcc -o main main.o foo.o bar.o
將這些目標文件鏈接成一個可執(zhí)行文件"main"。
總結
以上是生活随笔為你收集整理的Makefile中的CFLAGS、$^、$< 、$@的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 京东商品图片 自动下载 抓取 c#
- 下一篇: HGDB 兼容 Oracle 中 mer