您好,登錄后才能下訂單哦!
在 makefile 中是支持函數的概念的,make 解釋器提供了一系列的函數供 makefile 調用。在 makefile 中支持自定義函數實現,并調用執行;提供 define 關鍵字實現自定義函數。下面是自定義函數的語法
我們再來深入地看看自定義函數,自定義函數是一個多行變量,無法直接調用;其次自定義函數是一種過程調用,沒有任何的返回值;自定義函數用于定義命令集合,并應用規則中。下來我們還是以代碼為例來進行說明
.PHONY : test define func1 @echo "My name is $(0)" endef define func2 @echo "My name is $(0)" @echo "Param 1 => $(1)" @echo "Param 2 => $(2)" endef var := $(call func1) new := $(func1) test : @echo "new => $(new)" @echo "var => $(var)" $(call func1) #@echo My name is func1 $(call func2, D.T.Software, delphi_tang)
我們來看看編譯結果
我們看到 new 變量只打印了前面的,并么有打印 func1,因為自定義函數其本質是過程調用,沒有任何的返回值;而 var 前面加了 call,因此它會輸出函數名 func1。在直接進行 call func1 時,打印便是定義的字符串,它的參數 0 是函數名;call func2 時,加了兩個參數,因此參數 1 為 D.T.Software,參數 2 為 delphi_tang。下來我們來看看預定義函數的調用,格式如下
那么自定義函數和預定義函數的調用形式為何完全不同呢?我們來分析下 makefile 中的預定義函數,其實在 makefile 中是不支持真正意義上的自定義函數的,自定義函數的本質是多行變量;預定義的 call 函數在調用時將參數傳遞給多行變量,自定義函數是 call 函數的實參,并在 call 中被執行。
下來我們還是以代碼為例來進行說明
.PHONY : test define func1 @echo "My name is $(0)" endef define func2 @echo "My name is $(0)" endef var1 := $(call func1) var2 := $(call func2) var3 := $(abspath ./) var4 := $(abspath test.cpp) test : @echo "var1 => $(var1)" @echo "var2 => $(var2)" @echo "var3 => $(var3)" @echo "var4 => $(var4)"
程序中的 abspath 是輸出當前目錄的絕對路徑,我們來看看結果
我們看到 var1 和 var2 定義的分別是個自定義函數,因此輸出函數名;而 var3 是輸出當前目錄的絕對路徑,var4 是輸出當前目錄下的 test.cpp 路徑。結果也正是這樣的。通過對 makefile 中的函數定義及調用的學習,總結如下:1、make 解釋器提供了一系列的函數供 makefile 調用;2、自定義函數是一個多行變量,無法直接調用;3、自定義函數用于定義命令集合,并應用于規則中;4、預定義的 call 函數在調用時將參數傳遞給多行變量;5、自定義函數是 call 函數的實參,并在 call 中被執行。
歡迎大家一起來學習 makefile 語言,可以加我QQ:243343083。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。