? 筆者常年在Linux環(huán)境編程,經(jīng)常在項目中與Makefile打交道,最近總結(jié)了幾個Makefile的小的知識點,分享給大家。
通過閱讀本文,你將了解到以下知識:
- 1.Makefilke中的.PHONY的作用
- 2.Makefile中的各種賦值運算符號(= 、:= 、+= 、?=)的區(qū)別
Makefilke中的.PHONY的作用
先給大家一個簡單的Makefile,如下:
# This is a Makefile for learning makefile knowledge !!!
# Knowledge point:
# 1. What's the usage of ".PHONY" ?
# 2. What's the diffirences between "=", ":=", "?=", and "+=" ?
TEST_VARIABLE = "123"
TEST_VARIABLE ?= "456"
TEST_VARIABLE += "789"
all: some_targets
# Simulate to create the lastest target file.
@touch target_final_file && echo create target_final_file ...
@echo Make all targets done !!!
@echo ""
# @echo "TEST_VARIABLE=$(TEST_VARIABLE)"
@echo ""
TEST_VARIABLE := "abc"
some_targets:
# Simulate to create some target files.
@touch target_file1 && echo create target_file1 ...
@touch target_file2 && echo create target_file2 ...
@touch target_file3 && echo create target_file3 ...
@echo ""
# @echo "TEST_VARIABLE=$(TEST_VARIABLE)"
@echo ""
clean:
@echo Clean builded project.
@rm -rf target_file1 target_file2 target_file3 target_final_file
#.PHONY: clean some_targets
這個Makefile很簡單,Makefile的同級路徑,輸入make命令,則生成4個目標(biāo)文件target_file1 target_file2 target_file3 target_final_file;執(zhí)行make clean則刪除這4個生成的目標(biāo)文件。執(zhí)行效果如下圖所示:
看樣子沒有任何問題,那么如果在Makefile同級目錄有一個叫clean的文件呢?我們試下會發(fā)生什么?
從演示的效果看,make clean就報錯了,為啥會 “up to date"呢?還是不是因為“clean”這個文件的存在。
原來Makefile中的TARGET默認是個“文件”,如果不使用.PHONY指定一個TARGET是非文件的話,當(dāng)有一個與該TARGET同名的文件存在時,執(zhí)行這個TARGET的編譯命令就會報錯,如上面的例子,這個TARGET就是clean。
由此可見,.PHONY的作用就是申明一個TARGET是“偽TARGET”,不用為生成任何文件,自然不用檢查與其同名的文件。
我們測試下,加上.PHONY申明后的結(jié)果:
與我們預(yù)想的一樣,make clean順利執(zhí)行,生成的target文件刪除成功。
Makefile中的各種賦值運算符號的區(qū)別
在Makefile的規(guī)則寫法中,變量的賦值運算,有以下幾種方式:
TEST_VARIABLE = "123"
TEST_VARIABLE ?= "456"
TEST_VARIABLE += "789"
TEST_VARIABLE := "abc"
我們先給出結(jié)論:
= 是延緩賦值,語句執(zhí)行時,才會運算賦值,比如VARIABLE = `ls -al` ,只有當(dāng)使用到VARIABLE變量的時候,才會去執(zhí)行 ls -al命令求得VARIABLE的值。
?= 是判斷賦值,即當(dāng)變量在此之前沒有被賦值才會去執(zhí)行賦值,這個可以防止變量被多次賦值,或變量被覆蓋的情況。
+= 是疊加賦值,即變量在執(zhí)行+=運算后,會保留之前的值,同時會新增新加入的內(nèi)容,這個常用于對字符串的處理,可以等同于字符串的追加操作。
:= 是立即賦值,即變量會被立即執(zhí)行,比如VARIABLE := `ls -al` 在第一個出現(xiàn)這個語句的地方,就會被執(zhí)行l(wèi)s -la,之后都不會再執(zhí)行了,而是直接使用VARIABLE的值;它與 = 的最大區(qū)別,就是一個是【立即】,一個是【延緩】;適用于不同的應(yīng)用場景。
以上就是集中賦值運算的對比和區(qū)別,下面分析下開頭給出的Makefile實踐下。
這個是因為TEST_VARIABLE變量最后是用:=賦值的,所有它是最后生效的。其他幾種賦值的效果,留給讀者去驗證下吧。
如有疑問,歡迎在評論席指出。@_@
延伸閱讀:
【Linux + Makefile】簡單實用的Makefile模板來了
【Linux + Makefile】Makefile的高階用法:解決C文件包含的頭文件修改了,但C文件不重新編譯的問題
【Linux + Makefile】十分鐘教你學(xué)會Makefile的FORCE
?審核編輯:湯梓紅
-
Linux
+關(guān)注
關(guān)注
87文章
11232瀏覽量
208938 -
Makefile
+關(guān)注
關(guān)注
1文章
125瀏覽量
19163 -
RT-Thread
+關(guān)注
關(guān)注
31文章
1273瀏覽量
39929
發(fā)布評論請先 登錄
相關(guān)推薦
評論