Makefile 的引入及規(guī)則
gcc -o file file.c
預(yù)處理-編譯-匯編-鏈接 file.i -> file.s -> file.o -> file 缺點(diǎn)是對(duì)所有的文件再處理一次,在文件非常多時(shí)耗時(shí)非常長(zhǎng)盒音。應(yīng)該分別編譯睬涧,最后鏈接。
gcc -c -o a.o a.c
gcc -c -o b.o b.c
gcc -o test a.o b.o
如何判斷哪些文件被修改了溉贿?通過(guò)比較a.c(b.c,a.o b.o)與a.o(b.o浦旱,test)的文件最后修改時(shí)間宇色。
Makefile基本的語(yǔ)法規(guī)則
目標(biāo)文件:依賴文件1 依賴文件2 ....
[TAB]——命令
當(dāng)依賴比目標(biāo)新,執(zhí)行命令
test:a.o b.o
gcc -o test a.o b.o
a.o:a.c
gcc -c -o a.o a.c
b.o:b.c
gcc -c -o b.o b.c
a.通配符:%.o b.假想目標(biāo):.PHONY c.即時(shí)變量颁湖、延時(shí)變量宣蠕,export
a.通配符的用法舉例
test:a.o b.o
gcc -o test a.o b.o
%.o:%.c
gcc -c -o $@ $<
test:a.o b.o c.c
gcc -o test $^
%.o:%.c
gcc -c -o $@ $<
$@ 表示目標(biāo)
$< 表示第一個(gè)依賴文件
$^ 表示所有的依賴文件
b.假想目標(biāo)
test:a.o b.o c.c
gcc -o test $^
%.o:%.c
gcc -c -o $@ $<
clean:
rm *.o test
.PHONY:clean/*假想目標(biāo)*/
make [目標(biāo)名] 若無(wú)目標(biāo),執(zhí)行第一個(gè)
c.即時(shí)變量爷狈,延時(shí)變量
簡(jiǎn)單變量(即時(shí)變量):A := xxx #A的值即可確定 B = xxx #B的值使用到時(shí)才確定
A := abc
B = 123
all:
@echo $(A)
@echo $(B)
:= #即時(shí)變量
= #延時(shí)變量
?= #延時(shí)變量植影,如果是第一次定義才有效,如果在前面該變量已定義則忽略這句
+= #附加涎永,它是即時(shí)變量還是延時(shí)變量取決于前面的定義
Makefile函數(shù)
a. $(foreach var,list,text)
b. $(filter pattern...,text) 在text中取出符合pattern格式的值
$(filter-out pattern...,text) 在text中取出不符合pattern格式的值
c. $(wildcard pattern) pattern定義了文件名的格式思币,wildcard取出其中存在的文件
d. (var)) #從列表中取出每一個(gè)值,如果符合pattern則替換為replacement
Linux Makefile 生成 *.d 依賴文件及 gcc -M -MF -MP 等相關(guān)選項(xiàng)說(shuō)明 - Jerry - CSDN博客