資源描述:
《makefile指令詳解x》由會員上傳分享,免費在線閱讀,更多相關(guān)內(nèi)容在教育資源-天天文庫。
1、makefile簡介Makefile方便中大型程序項目的管理(不一定是基于C語言的項目)在Linux下通過make命令調(diào)用makefile腳本,根據(jù)其定義執(zhí)行shell命令行常用規(guī)則如果這個工程沒有編譯過,那么我們的所有c文件都要編譯并被鏈接。如果這個工程的某幾個c文件被修改,那么我們只編譯被修改的c文件,并鏈接目標程序。如果這個工程的頭文件被改變了,那么我們需要編譯引用了這幾個頭文件的c文件,并鏈接目標程序。Makefile格式target...:prerequisites...#注釋command...target:可以為可執(zhí)行文件,object文件,或標簽(l
2、abel)prerequisites:生成該target需要的文件/目標生成該target需要執(zhí)行的shell命令Makefileexampleedit:main.okbd.ocommand.occ-oeditmain.okbd.ocommand.omain.o:main.cdefs.hcc-cmain.ckbd.o:kbd.cdefs.hcommand.hcc-ckbd.ccommand.o:command.cdefs.hcommand.hcc-ccommand.cclean:rmeditmain.okbd.ocommand.omake工作原理make會在當前目錄
3、下找名字叫“Makefile”或“makefile”的文件。如果找到,它會找文件中的第一個目標文件(target),在上面的例子中,他會找到“edit”這個文件,并把這個文件作為最終的目標文件。如果edit文件不存在,或是edit所依賴的后面的.o文件的文件修改時間要比edit這個文件新,那么,他就會執(zhí)行后面所定義的命令來生成edit這個文件。make工作原理如果edit文件不存在,或是edit所依賴的后面的.o文件的文件修改時間要比edit這個文件新,那么,他就會執(zhí)行后面所定義的命令來生成edit這個文件。如果edit依賴的.o文件不存在,則找到后面對應的定義規(guī)則
4、來生成該.o文件。最后再用.o文件生成edit執(zhí)行文件變量的使用edit:main.okbd.ocommand.occ-oeditmain.okbd.ocommand.o…clean:rmeditmain.okbd.ocommand.oobjects=main.okbd.ocommand.oedit:$(objects)cc-oedit$(objects)…clean:rmedit$(objects)Make自動推導只要make看到一個[whatever.o]文件,它就會自動的把相應的[whatever.c]文件加在依賴關(guān)系中。并且也會把執(zhí)行命令cc–cwhatev
5、er.c推導出來。Make自動推導main.o:main.cdefs.hcc-cmain.ckbd.o:kbd.cdefs.hcommand.hcc-ckbd.ccommand.o:command.cdefs.hcommand.hcc-ccommand.cmain.o:defs.hkbd.o:defs.hcommand.hcommand.o:defs.hcommand.h.PHONY:cleanclean:rmedit$(objects)文件引用include;假如你有這樣幾個Makefile:a.mk、b.mk、c.mk,還有一個文件叫foo.
6、make,以及一個變量$(bar),其包含了e.mk和f.mk,includefoo.make*.mk$(bar)=ncludefoo.makea.mkb.mkc.mke.mkf.mk