1. makefile作用:
? ? ? ? 正常一個main函數(shù)通過編譯鏈接可以生成可執(zhí)行程序,例如:
? ? ? ? cc -c ?main.c ? #生成main.o文件 ? ? cc -o main main.o ?#生成main可執(zhí)行文件
? ? ? ? 但是當(dāng)一個大工程有大量源代碼文件和頭文件時咱筛,就需要多條命令才能完整編譯鏈接吹散。makefile定義了一系列的規(guī)則來指定丸升,哪些文件需要先編譯界赔,哪些文件需要后編譯,哪些文件需要重新編譯毯辅,甚至于進行更復(fù)雜的功能操作埂伦,就像一個Shell腳本一樣煞额。然后執(zhí)行make命令即可執(zhí)行思恐。
? ??????主要包含了五個東西:顯式規(guī)則、隱晦規(guī)則膊毁、變量定義胀莹、文件指示和注釋
2. makefile簡單示例
2.1 基本格式
target ... : prerequisites ...
????????command
target ? ? ? ? ????:目標(biāo)文件, 可以是 Object File, 也可以是可執(zhí)行文件
prerequisites :生成 target 所需要的文件或者目標(biāo)
command ? ? ?: make需要執(zhí)行的命令 (任意的shell命令), Makefile中的命令必須以 [tab] 開頭
2.2 簡單樣例
edit :main.o tool.o
? ??????cc -o edit main.o tool.o ? ? ? ? ? ? ? #如果長度太長,可以用 \ 換行編寫婚温,方便閱讀
main.o : hwl.h main.c
? ??????cc -c main.c
tool.o : hwl.h tool.c
? ??????cc -c tool.c
clean :
????????rm -rf edit main.o tool.o ? ? ? #注釋...反斜杠轉(zhuǎn)義 ?\#
? ? ? ? 上面的示例說明了edit文件依賴main.o和tool.o描焰,main.o依賴hwl.h和main.c。這同時說明了當(dāng)main.c更新了栅螟,main.o需要重新執(zhí)行生成荆秦,edit也進而需要重新生成。
????????clean是一個動作名字力图,像lable一樣步绸,其冒號后什么也沒有,那么make就不會去找文件的依賴性吃媒,也就不會自動執(zhí)行其后所定義的命令瓤介。執(zhí)行其后的命令要在make命令后指出這個lable的名字(比如 make clean)吕喘。
2.3 簡化
● ?例子中比如.o文件重復(fù)寫了多次,可以定義變量來替代刑桑,使用時通過$(var)調(diào)用
● ?GNU的make很強大氯质,它可以自動推導(dǎo)文件以及文件依賴關(guān)系后面的命令。make看到一個[.o]文件祠斧,它就會自動的把[.c]文件加在依賴關(guān)系中闻察,如果make找到一個main.o,那么main.c琢锋,就會是main.o的依賴文件蜓陌。并且 cc -c main.c 也會被推導(dǎo)出來,makefile也不用寫得這么復(fù)雜吩蔑。
OBJ=main.o tool.o
edit :$(OBJ)
cc -o edit main.o tool.o ? ? ? ? ? ? ?
main.o : hwl.h
tool.o : hwl.h
clean :
????????rm -rf edit $(OBJ)
3. make工作原理
● ? make會在當(dāng)前目錄下找名字”GNUmakefile“钮热、“Makefile”或“makefile”的文件。
? ? ? ? 建議使用Makefile烛芬,最好不要用“GNUmakefile”隧期,這個文件是GNU的make識別的。如果用其他的名字赘娄,就需要make命令顯示指定文件名仆潮。make -f 或make --file。
● ?如果找到遣臼,它會找文件中的第一個目標(biāo)文件(target)性置,并把這個文件作為最終的目標(biāo)文件。
● ?如果edit文件不存在揍堰,或是edit所依賴的后面的 .o 文件的文件修改時間要比edit這個文件新鹏浅,那么,他就會執(zhí)行后面所定義的命令來生成edit這個文件屏歹。
● ?如果edit所依賴的.o文件也不存在隐砸,那么make會在當(dāng)前文件中找目標(biāo)為.o文件的依賴性,如果找到則再根據(jù)那一個規(guī)則生成.o文件蝙眶。
● ?make會生成 .o 文件季希,然后再用 .o 文件生成執(zhí)行文件edit。