例解 Linux 下 Make 命令

發表於2016-12-04

Linux 下 make 命令是系統管理員和程式設計師用的最頻繁的命令之一。管理員用它通過命令列來編譯和安裝很多開源的工具,程式設計師用它來管理他們大型複雜的專案編譯問題。本文我們將用一些例項來討論 make 命令背後的工作機制。

Make 如何工作的

對於不知道背後機理的人來說,make 命令像命令列引數一樣接收目標。這些目標通常存放在以 “Makefile” 來命名的特殊檔案中,同時檔案也包含與目標相對應的操作。更多資訊,閱讀關於 Makefiles 如何工作的系列文章。

當 make 命令第一次執行時,它掃描 Makefile 找到目標以及其依賴。如果這些依賴自身也是目標,繼續為這些依賴掃描 Makefile 建立其依賴關係,然後編譯它們。一旦主依賴編譯之後,然後就編譯主目標(這是通過 make 命令傳入的)。

現在,假設你對某個原始檔進行了修改,你再次執行 make 命令,它將只編譯與該原始檔相關的目標檔案,因此,編譯完最終的可執行檔案節省了大量的時間。

Make 命令例項

下面是本文所使用的測試環境:

下面是工程的內容:

下面是 Makefile 的內容:

現在我們來看 Linux 下一些 make 命令應用的例項:

1. 一個簡單的例子

為了編譯整個工程,你可以簡單的使用 make 或者在 make 命令後帶上目標 all

你能看到 make 命令第一次建立的依賴以及實際的目標。

如果你再次檢視目錄內容,裡面多了一些 .o 檔案和執行檔案:

現在,假設你對 test.c 檔案做了一些修改,重新使用 make 編譯工程:

你可以看到只有 test.o 重新編譯了,然而另一個 Test.o 沒有重新編譯。

現在清理所有的目標檔案和可執行檔案 test,你可以使用目標 clean:

你可以看到所有的 .o 檔案和執行檔案 test 都被刪除了。

2. 通過 -B 選項讓所有目標總是重新建立

到目前為止,你可能注意到 make 命令不會編譯那些自從上次編譯之後就沒有更改的檔案,但是,如果你想覆蓋 make 這種預設的行為,你可以使用 -B 選項。

下面是個例子:

你可以看到儘管 make 命令不會編譯任何檔案,然而 make -B 會強制編譯所有的目標檔案以及最終的執行檔案。

3. 使用 -d 選項列印除錯資訊

如果你想知道 make 執行時實際做了什麼,使用 -d 選項。

這是一個例子:

這是很長的輸出,你也看到我使用了 more 命令來一頁一頁顯示輸出。

4. 使用 -C 選項改變目錄

你可以為 make 命令提供不同的目錄路徑,在尋找 Makefile 之前會切換目錄的。

這是一個目錄,假設你就在當前目錄下:

但是你想執行的 make 命令的 Makefile 檔案儲存在 ../make-dir/ 目錄下,你可以這樣做:

你能看到 make 命令首先切到特定的目錄下,在那執行,然後再切換回來。

5. 通過 -f 選項將其它檔案看作 Makefile

如果你想將重新命名 Makefile 檔案,比如取名為 my_makefile 或者其它的名字,我們想讓 make 將它也當成 Makefile,可以使用 -f 選項。

通過這種方法,make 命令會選擇掃描 my_makefile 來代替 Makefile。

相關文章