本文目錄一覽:
c語言 怎麼makefile
my_run_filename: main.o set1.o set2.o set3.o
gcc -o my_run_filename main.o set1.o set2.o set3.o
main.o: main.c
gcc -c main.c
set1.o: set1.c
gcc – c set1.c
set2.o: set2.c
gcc -c set2.c
set3.o:set3.c
gcc -c set3.c
雖然我以前也使用過 make 命令對 makefile 文件進行多個源文件進行編譯、鏈接,但是由於我已經很多年不編寫 C 語言程序了,所以也不敢說我寫的就完全正確。但是該 makefile的基本思路我可以給你解釋一下:
my_run_filename: main.o set1.o set2.o set3.o
gcc -o my_run_filename main.o set1.o set2.o set3.o
my_run_filename 是最終生成的可執行程序名,它依賴於四個中間文件(以 *.o 為結尾):main.o set1.o set2.o set3.o
生成該最終可執行的程序名的命令是:gcc -o my_run_filename main.o set1.o set2.o set3.o
main.o: main.c
gcc -c main.c
main.o 這個中間文件依賴於 main.c 源程序,其中:gcc -c main.c 代表只編譯、不鏈接。
gcc 的 -c 選項表示只產生 main.o 文件,等待所有模塊單獨編譯通過了之後,再和別的一起進行鏈接。
其它 set1、set2、set3 同理。
雖然我知道 makefile 的大致思路,但是給我印象最深的就是:make 工具 對 makefile 文本文件的書寫規則是相當苛刻的,你可能還需要花費較多的時間進行 make 調試。
編寫一個makefile文件主要包含哪些內容
一、Makefile里有什麼?
Makefile里主要包含了五個東西:顯式規則、隱晦規則、變數定義、文件指示和注釋。
1、顯式規則。顯式規則說明了,如何生成一個或多的的目標文件。這是由Makefile的書寫者明顯指出,要生成的文件,文件的依賴文件,生成的命令。
2、隱晦規則。由於我們的make有自動推導的功能,所以隱晦的規則可以讓我們比較粗糙地簡略地書寫Makefile,這是由make所支持的。
3、變數的定義。在Makefile中我們要定義一系列的變數,變數一般都是字元串,這個有點你C語言中的宏,當Makefile被執行時,其中的變數都會被擴展到相應的引用位置上。
4、文件指示。其包括了三個部分,一個是在一個Makefile中引用另一個Makefile,就像C語言中的include一樣;另一個是指根據某些情況指定Makefile中的有效部分,就像C語言中的預編譯#if一樣;還有就是定義一個多行的命令。有關這一部分的內容,我會在後續的部分中講述。
5、注釋。Makefile中只有行注釋,和UNIX的Shell腳本一樣,其注釋是用「#」字元,這個就像C/C++中的「//」一樣。如果你要在你的Makefile中使用「#」字元,可以用反斜框進行轉義,如:「\#」。
最後,還值得一提的是,在Makefile中的命令,必須要以[Tab]鍵開始。
誰能簡單明了的介紹一下c語言的makefile?
有篇《Linux下Makefile教程》值得一讀。
沒看懂Use this to make clean all and build all your exercises so far.的意思,先清理再構建?
對最開始的題可以這麼寫:
all:ext1
ext1:源文件
構建ext1的命令
.PHONY:all
然後make all和make ext1是一樣的效果。名字如果不是Makefile、makefile、GNUmakefile之一,用make -f Makefile文件名 all或make -f Makefile文件名 ext1。
makefile 文件介紹?
makefile文件主要有以下五種組成部分。顯式規則:顯式規則說明了生成一個或多個目標文件的方法和步驟。這是在編寫makefile文件時明顯指出的,包括要生成的文件、生成文件的依賴文件以及生成的命令等。隱式規則:由於make工具有自動推導的功能,所以在編寫makefile文件的時候可以利用該規則,簡略地書寫makefile。再由 make 工具本身自動推導需要使用的規則。變數的定義: make工具支持變數的定義,這些變數往往都是字元串,因此makefile中的變數更像是C語言中的宏。當makefile被執行時,其中的變數都會被展開到相應的引用位置上。
文件指示:其包括三個部分,一個是在一個makefile中引用另一個makefile,就像C語言中的include一樣。另一個是指根據某些情況指定makefile中的有效部分,就像C語言中的預編譯tlif一樣。還有就是定義一個多行的命令。
注釋: makefile 中支持行注釋,這一點需要特別注意。makefile 中的注釋和 shell腳本一樣,其注釋是用「#」字元。如果需要在 makefile中使用「#」字元,可以用『\』對其進行轉義。例如,「\#」表示一個『#』字元。makefile文件的文件名最好命名為makefile或者Makefile。因為在默認的情況下,make命令會在當前目錄下按順序找尋這兩個文件進行解釋。用戶也可以為makefile文件自定義一個文件名,例如,Make.makefile,Make.admin等。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/232130.html