您好,登錄后才能下訂單哦!
本篇內容介紹了“linux系統的編譯命令怎么用”的有關知識,在實際案例的操作過程中,不少人都會遇到這樣的困境,接下來就讓小編帶領大家學習一下如何處理這些情況吧!希望大家仔細閱讀,能夠學有所成!
linux系統的編譯命令是“Make”。在linux系統中,make是一個非常重要的編譯命令,管理員用它通過命令行來編譯和安裝很多開源的工具,程序員用它來管理他們大型復雜的項目編譯問題。make用于管理對于大型程序的自動編譯任務,自動決定程序某一部分需要重新編譯,并發出編譯指令。
make 是 linux 系統的實用程序。它用于管理對于大型程序的自動編譯任務,自動決定程序某一部分需要重新編譯,并發出編譯指令。雖然,我們最常見于 C 語言程序的編譯。但是,make 不限于某一特定語言,凡是可以通過 shell 命令來運行編譯器的語言都可以使用 make 。除此之外,你甚至可以用 make 描述任何構建任務,這些任務中,文件需要在其依賴的文件發生變動后自動更新。
對于不知道背后機理的人來說,make 命令像命令行參數一樣接收目標。這些目標通常存放在以 “Makefile” 來命名的特殊文件中,同時文件也包含與目標相對應的操作。更多信息,閱讀關于 Makefiles 如何工作的系列文章。
當 make 命令第一次執行時,它掃描 Makefile 找到目標以及其依賴。如果這些依賴自身也是目標,繼續為這些依賴掃描 Makefile 建立其依賴關系,然后編譯它們。一旦主依賴編譯之后,然后就編譯主目標(這是通過 make 命令傳入的)。
現在,假設你對某個源文件進行了修改,你再次執行 make 命令,它將只編譯與該源文件相關的目標文件,因此,編譯完最終的可執行文件節省了大量的時間。
下面是本文所使用的測試環境:
OS —— Ubunut 13.04
Shell —— Bash 4.2.45
Application —— GNU Make 3.81
下面是工程的內容:
$ ls
anotherTest.c Makefile test.c test.h
下面是 Makefile 的內容:
all: test test: test.o anotherTest.o
gcc -Wall test.o anotherTest.o -o testtest.o: test.c
gcc -c -Wall test.c
anotherTest.o: anotherTest.c
gcc -c -Wall anotherTest.c
clean:
rm -rf *.o test
現在我們來看 Linux 下一些 make 命令應用的實例:
為了編譯整個工程,你可以簡單的使用 make
或者在 make 命令后帶上目標 all
。
$ make
gcc -c -Wall test.c
gcc -c -Wall anotherTest.c
gcc -Wall test.o anotherTest.o -o test
你能看到 make 命令第一次創建的依賴以及實際的目標。
如果你再次查看目錄內容,里面多了一些 .o 文件和執行文件:
$ ls
anotherTest.c anotherTest.o Makefile test test.c test.h test.o
現在,假設你對 test.c 文件做了一些修改,重新使用 make 編譯工程:
$ make
gcc -c -Wall test.c
gcc -Wall test.o anotherTest.o -o test
你可以看到只有 test.o 重新編譯了,然而另一個 Test.o 沒有重新編譯。
現在清理所有的目標文件和可執行文件 test,你可以使用目標 clean
:
$ make clean
rm -rf *.o test$ ls
anotherTest.c Makefile test.c test.h
你可以看到所有的 .o 文件和執行文件 test 都被刪除了。
到目前為止,你可能注意到 make 命令不會編譯那些自從上次編譯之后就沒有更改的文件,但是,如果你想覆蓋 make 這種默認的行為,你可以使用 -B 選項。
下面是個例子:
$ make
make: Nothing to be done for `all’.$ make -B
gcc -c -Wall test.c
gcc -c -Wall anotherTest.c
gcc -Wall test.o anotherTest.o -o test
你可以看到盡管 make 命令不會編譯任何文件,然而 make -B
會強制編譯所有的目標文件以及最終的執行文件。
如果你想知道 make 執行時實際做了什么,使用 -d 選項。
這是一個例子:
$ make -d | more
GNU Make 3.81
Copyright (C) 2006 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.
There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A
PARTICULAR PURPOSE.
This program built for x86_64-pc-linux-gnu
Reading makefiles…
Reading makefile `Makefile’…
Updating makefiles….
Considering target file `Makefile’.
Looking for an implicit rule for `Makefile’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.o’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.c’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.cc’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.C’.
Trying pattern rule with stem `Makefile’.
Trying implicit prerequisite `Makefile.cpp’.
Trying pattern rule with stem `Makefile’.
--More--
這是很長的輸出,你也看到我使用了 more
命令來一頁一頁顯示輸出。
你可以為 make 命令提供不同的目錄路徑,在尋找 Makefile 之前會切換目錄的。
這是一個目錄,假設你就在當前目錄下:
$ ls
file file2 frnd frnd1.cpp log1.txt log3.txt log5.txt
file1 file name with spaces frnd1 frnd.cpp log2.txt log4.txt
但是你想運行的 make 命令的 Makefile 文件保存在 ../make-dir/ 目錄下,你可以這樣做:
$ make -C ../make-dir/
make: Entering directory `/home/himanshu/practice/make-dir’
make: Nothing to be done for `all’.
make: Leaving directory `/home/himanshu/practice/make-dir
你能看到 make 命令首先切到特定的目錄下,在那執行,然后再切換回來。
如果你想將重命名 Makefile 文件,比如取名為 my_makefile 或者其它的名字,我們想讓 make 將它也當成 Makefile,可以使用 -f 選項。
make -f my_makefile
通過這種方法,make 命令會選擇掃描 my_makefile 來代替 Makefile。
“linux系統的編譯命令怎么用”的內容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業相關的知識可以關注億速云網站,小編將為大家輸出更多高質量的實用文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。