對于makefile,掌握一個規則,兩個變量和三個函數。下面介紹一個規則。
makefile的作用:一個項目代碼的管理工具。當一個項目的代碼文件數(如.c文件)太多,用gcc編譯會太麻煩,如果全部文件一次性編譯,一個文件有錯誤,所有文件都需要重新編譯。如果每個文件單獨編譯,則十分麻煩。因此,就有項目代碼管理工具makefile。項目代碼編譯管理;節省編譯項目的時間;一次編寫,終身受益。
[root@localhost src]# ls
add.c ?div.c ?libM1.so ?main.c ?mul.c ?sub.c
[root@localhost src]# gcc -pedantic -Wall -pipe -ggdb3 *.c -o zsx -I ../include/
[root@localhost src]# ls
add.c ?div.c ?libM1.so ?main.c ?mul.c ?sub.c ?zsx? //可以看出最終只是生成了zsx目標文件,因此有一個.c文件改變了,就會全部重新編譯,然后鏈接。
[root@localhost src]# ./zsx?
sum = 26
?
規則如下:
規則中的三要素:目標,依賴,命令
目標:依賴條件
?????? 命令? //tab縮進,必須要縮進
[root@localhost src]# ls
add.c ?div.c ?libM1.so ?main.c ?mul.c ?sub.c
[root@localhost src]# vim makefile
zsx:main.c sub.c add.c mul.c div.c
? ? ? ? gcc -pipe -pedantic -Wall -ggdb3 main.c sub.c add.c mul.c div.c -o zsx -I ../include //第二行必須有一個tab縮進
[root@localhost src]# make
gcc -pipe -pedantic -Wall -ggdb3 main.c sub.c add.c mul.c div.c -o zsx -I ../include
[root@localhost src]# ls
add.c ?div.c ?libM1.so ?main.c ?makefile ?mul.c ?sub.c ?zsx
[root@localhost src]# ./zsx
sum = 26
//上述中,生成的最終文件zsx自動會跟makefile文件在同一個目錄。注意兩點:1.對于依賴條件中的幾個文件如果不跟makefile在同一個目錄的話,必須指定其所在目錄(如../main.c、/mnt/hgfs/shared/ggc/Calc/add.c等),這樣makefile才能找到依賴條件所需的文件在哪里;2.在命令中,要分析清楚該命令是否需要指出頭文件、庫文件(-I? -L? -static? -l)。
舉例:
[root@localhost src]# ls
add.c ?div.c ?libM1.so ?main.c ?makefile ?mul.c ?sub.c
[root@localhost src]# vim makefile
zsx:main.o add.o sub.o mul.o div.o
? ? ? ? gcc -ggdb3 main.o add.o sub.o mul.o div.o -o zsx
main.o:main.c
? ? ? ? gcc -pedantic -Wall -pipe -c main.c -o main.o -I ../include
add.o:add.c
? ? ? ? gcc -pedantic -Wall -pipe -c add.c -o add.o
sub.o:sub.c
? ? ? ? gcc -pedantic -Wall -pipe -c sub.c -o sub.o?
mul.o:mul.c
? ? ? ? gcc -pedantic -Wall -pipe -c mul.c -o mul.o?
div.o:div.c
? ? ? ? gcc -pedantic -Wall -pipe -c div.c -o div.o
[root@localhost src]# make
gcc -pedantic -Wall -pipe -c main.c -o main.o -I ../include? //生成main.o
gcc -pedantic -Wall -pipe -c add.c -o add.o //生成add.o
gcc -pedantic -Wall -pipe -c sub.c -o sub.o //生成sub.o
gcc -pedantic -Wall -pipe -c mul.c -o mul.o //生成mul.o
gcc -pedantic -Wall -pipe -c div.c -o div.o //生成div.o
gcc -ggdb3 main.o add.o sub.o mul.o div.o -o zsx? //生成最終目標? 且最后鏈接時加上調試信息 -ggdb3
[root@localhost src]# ./zsx
sum = 26
[root@localhost src]# ls
add.c ?add.o ?div.c ?div.o ?libM1.so ?main.c ?main.o ?makefile ?mul.c ?mul.o ?sub.c ?sub.o ?zsx? //可以看出,既生成了以及中間文件.o,還生成了最終目標文件zsx。因為幾個中間文件.o在makefile中也是目標文件,為次級目標文件。
[root@localhost src]# make
make: `zsx' is up to date.? //可以發現再次make沒有反應,這是因為make檢測到所有的文件都是最新的(即沒有改動過),因此不需要再次做重復的工作。
[root@localhost src]# rm -f zsx
[root@localhost src]# make
gcc -ggdb3 main.o add.o sub.o mul.o div.o -o zsx? //此時make有了反應,因為make檢測到zsx目標文件刪除了,因此只需要執行最后一步鏈接操作即可。
[root@localhost src]# ./zsx
sum = 26
[root@localhost src]# vim add.c?? //修改了add.c的內容
[root@localhost src]# make
gcc -pedantic -Wall -pipe -c add.c -o add.o?? //只是重新編譯了add.c,編譯很費時間
gcc -ggdb3 main.o add.o sub.o mul.o div.o -o zsx? ? //更新最終目標, 鏈接不費時間
//最終目標一定要寫在第一行,如果未寫在第一行,則需要:all:zsx ?--> all指定生成的最終目標為zsx
總結:
?