全面解析Linux Make規(guī)則
隨著Linux的深入了解,我們知道為什么Linux會(huì)趕上微軟。在當(dāng)今社會(huì)Linux越來(lái)越成為主流,本文為你詳細(xì)介紹Linux Make規(guī)則,為你在學(xué)習(xí)Linux Make規(guī)則時(shí)起一定的作用。這是一段在Makefile中常見的規(guī)則 。
- clean:
- rm -r core *.o *.a tmp_make
- for i in *.c; do rm -f `basename $$i .c`.s; done
- (cd chr_drv; make clean)
- (cd blk_drv; make clean)
- (cd math; make clean)
第一句的 rm -f core *. *.a tmp_make 作用只是刪除文件,意思直白,沒(méi)什么好說(shuō)的。
第二句 for 循環(huán)遍歷目錄下所有的文件,將所有后綴名為.c文件名依次賦給i。然后執(zhí)行do語(yǔ)句,當(dāng)符合循環(huán)結(jié)束是執(zhí)行done??梢哉f(shuō)這里的for和shell里for語(yǔ)法是如此貌似。
我們可以來(lái)做個(gè)實(shí)驗(yàn)來(lái)驗(yàn)證一下:
- $ mkdir test #建立個(gè)實(shí)驗(yàn)用的目錄
- $ cd test
- $ touch a.x #建幾個(gè)實(shí)驗(yàn)用的文件
- $ touch b.x
- $ touch yy.x
- $ vi Makefile #寫個(gè)實(shí)驗(yàn)?zāi)_本
在文件中寫入:
clean:
for i in *.x; do echo $$i; done
寫好后,保存退出。運(yùn)行命令:
$ make
隨后可看到輸出的結(jié)果:
- for i in *.x;do echo $i;done
- a.x
- b.x
- yy.x
看到結(jié)果,for語(yǔ)句實(shí)現(xiàn)的功能就很清楚了。
對(duì)于結(jié)果,有一個(gè)怪異的就是,原來(lái)腳本中的$$i,在輸出是就變成了$i。這時(shí)的for是不是就是一樣了?,F(xiàn)在可以先做個(gè)結(jié)論,make處理腳本可shell處理腳本幾乎雷同,只是個(gè)別情況下要做變通。make會(huì)對(duì)$x進(jìn)行擴(kuò)展。比如:
- ec=echo
- test:
- $(ec) 'ddd'
就可以在屏幕上看到輸出:
- echo 'ddd'
- ddd
所以應(yīng)該是make對(duì)Makefile進(jìn)行處理,將其變成shell可執(zhí)行的腳本,最后由shell解釋器來(lái)執(zhí)行有make翻譯過(guò)的腳本。并且是翻譯一句然后shell執(zhí)行一句,對(duì)于這個(gè)可以再做個(gè)驗(yàn)證。
- e =echo
- prt=ls
- clean:
- $(prt)
- for i in *.x;do $e $$i;done
其輸出為:
- ls
- a.sh a.x b.x Makefile yy.x
- for i in *.x;do echo $i;done
- a.x
- b.x
- yy.x
可以看到,$(prt)被擴(kuò)展后就立即執(zhí)行了。后面的for也是這樣。
到這里開篇的那個(gè)例子算是解析完畢了。下面在看看Makefile中的規(guī)則定義,在make中的規(guī)則分為兩種,一種是顯示規(guī)則,另一種無(wú)可爭(zhēng)議的就是隱含規(guī)則了。
顯示規(guī)則,定義如下
目標(biāo)文件 : 依賴文件
生成目標(biāo)文件的規(guī)則
隱含規(guī)則
.源文件擴(kuò)展名.目標(biāo)文件擴(kuò)展名:
生成目標(biāo)文件的規(guī)則
在使用隱含規(guī)則時(shí)要使用一些內(nèi)定宏來(lái)指定文件名:
$@ 全路徑的目標(biāo)文件
$* 去除擴(kuò)張名的全路徑的目標(biāo)文件
$? 所有源文件名
$< 源文件名
以上就是Linux Make規(guī)則的知識(shí)。
【編輯推薦】






















