有了這個Makefile文件撕予,不論我們什么時候修改了源程序當中的什么文件逃呼,我們只要執(zhí)行make命令绞惦,我們的編譯器都只會去編譯和我們修改的文件有關(guān)的文件逼纸,其它的文件它連理都不想去理的。
下面我們學習Makefile是如何編寫的济蝉。
在Makefile中也#開始的行都是注釋行.Makefile中最重要的是描述文件的依賴關(guān)系的說明杰刽。一般的格式是:
target:components
TAB rule
第一行表示的是依賴關(guān)系。第二行是規(guī)則王滤。
比如說我們上面的那個Makefile文件的第二行贺嫂。
main:main.o mytool1.o mytool2.o
表示我們的目標(target)main的依賴對象(components)是main.o mytool1.omytool2.o 當倚賴的對象在目標修改后修改的話,就要去執(zhí)行規(guī)則一行所指定的命令雁乡。就象我們的上面那個Makefile第三行所說的一樣要執(zhí)行 gcc-o main main.o mytool1.o mytool2.o 注意規(guī)則一行中的TAB表示那里是一個TAB鍵
Makefile有三個非常有用的變量第喳。分別是$@,$^踱稍,$<代表的意義分別是:
$@--目標文件曲饱,$^--所有的依賴文件悠抹,$<--第一個依賴文件。
如果我們使用上面三個變量扩淀,那么我們可以簡化我們的Makefile文件為:
# 這是簡化后的Makefile
main:main.o mytool1.o mytool2.o
gcc -o $@ $^
main.o:main.c mytool1.h mytool2.h
gcc -c $<
mytool1.o:mytool1.c mytool1.h
gcc -c $<
mytool2.o:mytool2.c mytool2.h
gcc -c $<
經(jīng)過簡化后,我們的Makefile是簡單了一點楔敌,不過人們有時候還想簡單一點。這里我們學習一個Makefile的缺省規(guī)則
.c.o:
gcc -c $<
這個規(guī)則表示所有的 .o文件都是依賴與相應(yīng)的.c文件的驻谆。例如mytool.o依賴于mytool.c這樣Makefile還可以變?yōu)椋?/p>
# 這是再一次簡化后的Makefile
main:main.o mytool1.o mytool2.o
gcc -o $@ $^
.c.o:
gcc -c $<
好了卵凑,我們的Makefile 也差不多了,如果想知道更多的關(guān)于Makefile的規(guī)則胜臊,可以查看相應(yīng)的文檔勺卢。