ps: 這里 不是很明白?尤其是 后面 三個變量,什么區別?
$@ 代表目標
$^ 代表全部依賴
$< 第一個依賴
$? 第一個變化的依賴
- makefile
makefile 命名規則makefileMakefile
makefile 三要素目標依賴規則命令
寫法:
目標:依賴
tab鍵規則命令
可以定義變量 srcFiles=main.c jia.c jian.c cheng.c chu.c
變量的使用:$(srcFiles), $(變量名)
makefile隱含規則:默認處理第一個目標
函數:wildcard 可以進行文件匹配patsubst 內容的替換
makefile的變量$@ 代表目標$^ 代表全部依賴$< 第一個依賴$? 第一個變化的依賴
代碼示例:
srcFiles=$(wildcard *.c)
objFiles=$(patsubst %.c, %.o, $(srcFiles))
headPath=./head
# 定義偽目標, 如果指向生成app1,就執行 make app1
all:app1 app2app1:$(objFiles)gcc $(objFiles) -o $@ -I $(headPath)app2:$(objFiles)gcc $(objFiles) -o $@ -I $(headPath)%.o:%.cgcc -c $< -I $(headPath) -o $@#.PHONY 防止目標有歧義
.PHONY:clean alltest:# - 的作用是 就算這行出錯了,下面的也要繼續執行# @的作用是 不顯示輸出-@echo $(srcFiles)echo $(objFiles)clean:rm -rf *.orm -rf app1 app2
執行指定的makefile
make -f makefile1
注意事項:
如果出現了 :*** missing separator. Stop.錯誤
在/etc/vim/vimrc 文件里面,添加這樣一句
autocmd FileType make set noexpandtab