分類

展開全部 | 收合全部

分類

展開全部 | 收合全部

【C++ Makefile #5】Makefile 內建變數 -「$@」, 「$^」, 「$<」, 「$* 」,「$? 」

前言

今天我們要來繼續討論 Makefile,
(這個是 day 3 的延伸討論)
Makefile 裡面常常造成新手閱讀困擾的「$開頭的」這些符號,
「$@」, 「$^」, 「$<」, 「$* 」,「$? 」,
我們今天來一個個分析他們。

讓 Makefile 超級難閱讀的關鍵字元XDDD,為了看懂就學一下吧!

介紹「$@」, 「$^」, 「$<」, 「$* 」,「$? 」

我們一樣先對 makefile 的邏輯有個概念,依照以下的格式:

target: dependency
  1. target 是我們要製作的檔案,
  2. dependency 是我們產生目標檔案的前置需求。
  • 「$@」: 取代 target 名稱,因為我們時常會讓 target 等同於要製作出的檔名,我們就會使用「$@」代替
  • 「$^」: 在多參數的時候,「^」取代的是全部的 dependency,也就是所有做為參數的都會被「$^」參考到。
  • 「$<」: 代表的是第一個 dependency
  • 「$* 」: 代表的是第一個 dependency,但不包含副檔名。
  • 「$? 」: 代表比 targets 還新的 dependency。(在 dependencies 中,有更新需要被重新修改的項目)

範例1

all: library.cpp main.cpp

結果

  • 「$@」: all
  • 「$<」: library.cpp
  • 「$^」: library.cpp main.cpp

範例2

all: test1 test2 test3
    @echo "test1 test2 test3"
    @echo "@=$@"
    @echo "^=$^"
    @echo "?=$?"
    @echo "<=$<"
    @echo "*=$*"

test1:
    @echo "test1"
test2:
    @echo "test2"
test3:
    @echo "test3"
clean:
    @echo "clean"

結果

make
test1
test2
test3
test1 test2 test3
@=all
^=test1.cpp test2.cpp test3.cpp
?=test1.cpp test2.cpp test3.cpp
<=test1.cpp
*=

範例3 – 印出變數

  • 「$* 」: 目前看起來最常用到的用法,我自己普遍看到都是拿來印變數。
abc=123

# print variable
print-% : ; @echo $* = $($*)

結果

> make print-abc
abc = 123

Reference

⭐C++ 基礎用法 相關文章整理⭐:
1.【C++】C++ compile 程式碼 使用 c++ 11 與使用相關的 package
2.【C++】C/C++ 顯示資料的類別 (type) sample code (內含範例程式碼) print C data type, cout C++ data type, get variable type in c++
3.【C++】C++ 複製 2D array的方法 copy 2d array memcpy sample code (內含範例程式碼)
⭐Modern C++ ⭐:
⭐C++ 字串處理相關文章整理⭐:
1.【C++】字串 char string stringstream 相關用法總整理 (內含範例程式碼) 與利用 sprinf, snprinf assign 值的方法
2.【C++】字串 char string stringstream 「轉換」用法總整理 (內含範例程式碼)
3.【C】printf, fprintf, sprintf, snprintf 相關用法總整理 (內含範例程式碼)
4.【C++】C++ String 用法 連接兩個 String c++ string concat
⭐C++ 系統偵測相關文章整理⭐:
1.【C++】C++ 利用 dirent.h 計算資料夾的檔案數量 count files sample code (內含範例程式碼)
2.【C++】C++ inotify sample code 偵測指定路徑底下的文件變化 (內有範例程式碼)
⭐C++ OpenCV 相關文章整理⭐:
1.【OpenCV】c++ OpenCV – 在 ubuntu 上第一次執行 OpenCV 程式 sample code (內含範例程式碼)
2.【OpenCV】c++ OpenCV - 在圖片上寫上文字 cv::putText sample code (內含範例程式碼)
3.【OpenCV】c++ OpenCV - cv::Rect 矩形用法與相關功能函數 sample code (內含範例程式碼)
4.【OpenCV】c++ OpenCV - OpenCV 中的純量 定義顏色 cv::Scalar(255,255,255) color sample code (內含範例程式碼)
5.【OpenCV】用 C++ 計算 iou 的方法 與網路算法常見錯誤(內附範例程式碼) sample code
⭐C++ Makefile 相關文章整理⭐:
1.【C++ Makefile】- 1 / 嘗試撰寫自己的第一份 Makefile
2.【C++ Makefile】- 2 / 新增自己的變數
3.【C++ Makefile】- 3 / Makefile 常用變數 -「$@」, 「$^」
4.【C++ Makefile】- 4 / Makefile 常用 fake target -「.PHONY」
5.【C++ Makefile】- 5 / Makefile 內建變數 -「$@」, 「$^」, 「$<」, 「$* 」,「$? 」
⭐【喜歡我的文章嗎? 歡迎幫我按讚~ 讓基金會請創作者喝一杯咖啡!
如果喜歡我的文章,請幫我在下方【按五下Like】 (Google, Facebook 免註冊),會由 「LikeCoin」 贊助作者鼓勵繼續創作,讀者們「只需幫忙按讚,完全不用出錢」哦!

likecoin-steps
Howard Weng
Howard Weng

我是 Howard Weng,很多人叫我嗡嗡。這個網站放了我的各種筆記。希望這些筆記也能順便幫助到有需要的人們!如果文章有幫助到你的話,歡迎幫我點讚哦!
另外,因為定位是「個人的隨手筆記」,有些文章內容「⚠️可能我理解有誤⚠️」或「?只寫到一半?」,如果有發現這樣的情況,歡迎在該文章的最下面留言提醒我!我會儘快修正或補上!感謝大家的建議與幫忙,讓網站能變得更好?

文章: 890

★留個言吧!內容有誤或想要補充也歡迎與我討論!