在 makefile 中是支持程序設計語言中變量的概念的,makefile 中的變量只代表文本數據(字符串)。那么在 makefile 中的變量名的規則又有哪些呢?a> 變量名可以包含字符、數字以及下劃線;b> 不能包含 ":" , "#" , "=" 或 " ";c> 變量名大小寫敏感。下來我們來看看變量的定義和使用,如下
創新互聯建站專注于企業營銷型網站、網站重做改版、開平網站定制設計、自適應品牌網站建設、H5高端網站建設、商城網站建設、集團公司官網建設、外貿營銷網站建設、高端網站制作、響應式網頁設計等建站業務,價格優惠性價比高,為開平等各大城市提供網站開發制作服務。
下來我們以代碼為例來進行分析說明
CC := gcc TARGET := hello.out $(TARGET) : func.o main.o $(CC) -o $(TARGET) func.o main.o func.o : func.c $(CC) -o func.o -c func.c main.o : main.c $(CC) -o main.o -c main.c .PHONY : rebuild clean all rebuild : clean all all : $(TARGET) clean : rm *.o $(TARGET)
我們來看看編譯結果是否和之前一樣
效果和之前是一樣的,那么我們為何這樣定義變量呢?在一些大型的工程項目中,我們可能要編譯好幾個版本,因此定義不同的 TARGET 便會編譯出不同的版本。而且這種方法還有個好處就是編譯器可以由我們自定義選擇,比如我們將上面的 gcc 編譯器換成 g++,則只需將 CC := gcc 換成 CC := g++,下來我們來看看編譯效果
我們看到編譯器已經換為 g++ 了。下來我們來講講 makefile 中變量的賦值方式,分為四種:a> 簡單賦值(:=);b> 遞歸賦值(=);c> 條件賦值(?=);d> 追加賦值(+=)。那么不同的賦值方式其意義是不同的!下來我們來對這四種賦值方式進行一一的解釋說明
a> 簡單賦值(:=):程序設計語言中的通用的賦值方式,只針對當前語句的變量是有效的。其用法如下
b> 遞歸賦值(=):賦值操作可能影響多個其他變量,所有與目標變量相關的其他變量都將受到影響。其用法如下
c> 條件賦值(?=):如果變量未定義,使用賦值符號中的值定義變量;如果變量已經定義,則賦值無效。其用法如下
d> 追加賦值(+=):原變量值之后加上一個新值,原變量值與新值之間由空格隔開。其用法如下
下來我們還是以代碼為例來進行說明
# ex1 (:=) x := foo y := $(x)b x := new .PHONY : test test : @echo "# ex1 (:=)" @echo "x => $(x)" @echo "y => $(y)"
經過簡單賦值后,x 就為 new 了,而 y 則應該為 foob。我們來看看編譯效果
我們看到結果和我們所分析的是一樣的。下來我們來看看遞歸賦值
# ex2 (=) x = foo y = $(x)b x = new .PHONY : test test : @echo "# ex2 (=)" @echo "x => $(x)" @echo "y => $(y)"
我們分析下,因為遞歸賦值是與目標相關的其他變量都會受到影響,那么 x 最后應該為 new,y 就應該為 newb。我們來看看編譯結果
為了更加形象對遞歸賦值進行說明,我們編寫代碼如下
a = $(b) b = $(c) c = hello-makefile .PHONY : test test : @echo "# ex2 (=)" @echo "x => $(x)" @echo "y => $(y)" @echo "a => $(a)" @echo "b => $(b)" @echo "c => $(c)"
我們定義 a 依賴于 b,而 b 依賴于 c。此時 c 為 hello-makefile,那么依賴于它的 b 也就變為 hello-makefile 了,此時依賴于 b 的 a 也就變為 hello-makefile 了。x 和 y 此時沒定義,看看編譯會報錯嗎?
編譯是通過的,證明在 makefile 中是支持這樣的寫法的,x 和 y 沒定義,自然也就為空了。那么 a,b,c 和我們所分析的是一樣的。所以在 makefile 中我們一般是很少直接用遞歸賦值的,因為有可能會意想不到地改變依賴于它的目標。下來我們來看看條件賦值
# ex3 (?=) x := foo y := $(x)b x ?= new .PHONY : test test : @echo "# ex3 (?=)" @echo "x => $(x)" @echo "y => $(y)"
我們在最后對 x ?= new,意思是如果前面沒定義的話,此時它便為 new。所以 x 最后應該為 foo,y 就應該為 foob。我們來看看編譯結果
結果確實是這樣的,一般我們會在新定義變量時采用這樣的寫法,以防止改變之前定義時的語義。最后看看追加賦值
# ex4 (+=) x := foo y := $(x)b x += new .PHONY : test test : @echo "# ex4 (+=)" @echo "x => $(x)" @echo "y => $(y)"
根據追加賦值的定義,它是直接在后面加上,但是有一個空格。所以 x 最后應該為 foo new,y 就應該為 foob。我們來看看編譯結果
我們看懂啊效果確實是這樣的,通過對四種賦值方式的學習,我們發現簡單賦值是跟 C 語言中是一樣的。追加賦值和 C++ 語言中的語義也是一樣的,一般在大型項目中是不會采用遞歸賦值這種寫法的。
歡迎大家一起來學習 makefile,可以加我QQ:243343083。
本文標題:變量和不同的賦值方式(四)
URL網址:http://vcdvsql.cn/article14/gjjdge.html
成都網站建設公司_創新互聯,為您提供網站策劃、小程序開發、網站設計公司、網站維護、網站收錄、手機網站建設
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯