亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

linux中makefile指的是什么

發布時間:2021-11-26 14:35:04 來源:億速云 閱讀:204 作者:小新 欄目:建站服務器

小編給大家分享一下linux中makefile指的是什么,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

在linux中,makefile是一個工程文件的編譯規則,描述了整個工程的編譯和鏈接等規則;其中包含了哪些文件需要編譯,哪些文件不需要編譯,哪些文件需要先編譯,哪些文件需要后編譯,哪些文件需要重建等等。

本教程操作環境:linux5.9.8系統、Dell G3電腦。

1、什么是 Makefile

Makefile 可以簡單的認為是一個工程文件的編譯規則,描述了整個工程的編譯和鏈接等規則。

一個企業級項目,通常會有很多源文件,有時也會按功能、類型、模塊分門別類的放在不同的目錄中,有時候也會在一個目錄里存放了多個程序的源代碼。

而Makefle就是針對如何對上述的一些代碼進行編譯的問題而生的,它定義了一套規則,決定了哪些文件要先編譯,哪些文件后編譯,哪些文件要重新編譯。

編譯整個工程需要涉及到的,在 Makefile 中都可以進行描述。換句話說,Makefile 可以使得我們的項目工程的編譯變得自動化,不需要每次都手動輸入一堆源文件和參數。

Makefile 的優點就是可以實現“自主編譯”,整個工程通常只要一個make命令就可以完成編譯、鏈接,甚至更復雜的功能。可以說,任何一個Linux源程序都帶有一個Makefile文件。

2.Makefile的優點

  • 管理代碼的編譯,決定該編譯什么文件,編譯順序,以及是否需要重新編譯;

  • 節省編譯時間。如果文件有更改,只需重新編譯此文件即可,無需重新編譯整個工程;

  • 一勞永逸。Makefile通常只需編寫一次,后期就不用過多更改。

3.命名規則

一般來說將Makefile命名為Makefilemakefile都可以,但很多源文件的名字是小寫的,所以更多程序員采用的是Makefile的名字,因為這樣可以將Makefile居前顯示。

如果將Makefile命為其它名字,比如Makefile_demo,也是允許的,但使用的時候應該采用以下方式:

make -f Makefile_demo

4.基本規則

Makefile的基本規則為:

                目標:依賴

                (tab)規則

目標 --> 需要生成的目標文件

依賴 --> 生成該目標所需的一些文件

規則 --> 由依賴文件生成目標文件的手段

tab --> 每條規則必須以tab開頭,使用空格不行

例如我們經常寫的gcc test.c -o test,使用Makefile可以寫成:

test: test.c
    gcc test.c -o test

其中,第一行中的test就是要生成的目標,test.c就是依賴,第二行就是由test.c生成test的規則。

Makefile中有時會有多個目標,但Makefile會將第一個目標定為終極目標

5.工作原理

目標的生成:

a. 檢查規則中的依賴文件是否存在;

b. 若依賴文件不存在,則尋找是否有規則用來生成該依賴文件。

linux中makefile指的是什么

比如上圖中,生成calculator的規則是gcc main.o add.o sub.o mul.o p.o -o,Makefil會先檢查main.o, add.o, sub.o, mul.o, p.o是否存在,如果不存在,就會再尋找是否有規則可以生成該依賴文件。

比如缺少了main.o這個依賴,Makefile就會在下面尋找是否有規則生成main.o。當它發現gcc main.c -o main.o這條規則可以生成main.o時,它就利用此規則生成main.o,然后再生成終極目標calculator。

整個過程是向下尋找依賴,再向上執行命令,生成終極目標。

目標的更新:

a. 檢查目標的所有依賴,任何一個依賴有更新時,就重新生成目標;

b. 目標文件比依賴文件時間晚,則需要更新。

linux中makefile指的是什么

比如,修改了main.c,則main.o目標會被重新編譯,當main.o更新時,終極目標calculator也會被重新編譯。其它文件的更新也是類推。

6.命令執行

make:

使用此命令即可按預定的規則生成目標文件。

如果Makefile文件的名字不為Makefile或makefile,則應加上-f選項,比如:

make -f Makefile_demo

make clean:

清除編譯過程中產生的中間文件(.o文件)及最終目標文件。

如果當前目錄下存在名為clean的文件,則該命令不執行。

-->解決辦法:偽目標聲明:.PHONY:clean

特殊符號:

- :表示此命令即使執行出錯,也依然繼續執行后續命令。如:

-rm a.o build/

@:表示該命令只執行,不回顯。一般規則執行時會在終端打印出正在執行的規則,而加上此符號后將只執行命令,不回顯執行的規則。如:

@echo $(SOURCE)

7.普通變量

變量定義及賦值:

變量直接采用賦值的方法即可完成定義,如:

INCLUDE = ./include/

變量取值:

用括號括起來再加個美元符,如:

FOO = $(OBJ)

系統自帶變量:

通常都是大寫,比如CC,PWD,CFLAG,等等。

有些有默認值,有些沒有。比如常見的幾個:

CPPFLAGS : 預處理器需要的選項 如:-I

CFLAGS:編譯的時候使用的參數 –Wall –g -c

LDFLAGS :鏈接庫使用的選項 –L -l

變量的默認值可以修改,比如CC默認值是cc,但可以修改為gcc:CC=gcc

8.自動變量

常用自動變量:

Makefile提供了很多自動變量,但常用的為以下三個。這些自動變量只能在規則中的命令中使用,其它地方使用都不行。

$@ --> 規則中的目標

$< --> 規則中的第一個依賴條件

$^ --> 規則中的所有依賴條件

例如:

app: main.c func1.c fun2.c

gcc $^ - o $@

其中:$^表示main.c func1.c fun2.c,$<表示main.c,$@表示app。

模式規則:

模式規則是在目標及依賴條件中使用%來匹配對應的文件,比如在目錄下有main.c, func1.c, func2.c三個文件,對這三個文件的編譯可以由一條規則完成:

%.o:%.c

$(CC) –c  $< -o $@

這條模式規則表示:

main.o由main.c生成,

func1.o由func1.c生成,

func2.o由func2.c生成

這就是模式規則的作用,可以一次匹配目錄下的所有文件。

9.函數

makefile也為我們提供了大量的函數,同樣經常使用到的函數為以下兩個。需要注意的是,makefile中所有的函數必須都有返回值。在以下的例子中,假如目錄下有main.c,func1.c,func2.c三個文件。

wildcard:

用于查找指定目錄下指定類型的文件,跟的參數就是目錄+文件類型,比如:

src = $(wildcard ./src/*.c)

這句話表示:找到./src 目錄下所有后綴為.c的文件,并賦給變量src。

命令執行完成后,src的值為:main.c func1.c fun2.c。

patsubst:

匹配替換,例如以下例子,用于從src目錄中找到所有.c 結尾的文件,并將其替換為.o文件,并賦值給obj。

obj = $(patsubst %.c ,%.o ,$(src))

把src變量中所有后綴為.c的文件替換成.o。

命令執行完成后,obj的值為main.o func1.o func2.o

特別地,如果要把所有.o文件放在obj目錄下,可用以下方法:

ob = $(patsubst ./src/%.c, ./obj/%.o, $(src))

以上是“linux中makefile指的是什么”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

喜德县| 西平县| 盐城市| 改则县| 定西市| 鄯善县| 太白县| 昭平县| 来凤县| 东乡族自治县| 冷水江市| 凯里市| 体育| 屏南县| 尉氏县| 洞口县| 五莲县| 齐齐哈尔市| 红桥区| 辽宁省| 西乌珠穆沁旗| 静安区| 巧家县| 泾源县| 胶州市| 松原市| 宜兴市| 温泉县| 泗阳县| 沙雅县| 武汉市| 萍乡市| 洛南县| 万宁市| 昆山市| 华阴市| 常州市| 唐河县| 墨竹工卡县| 宝丰县| 延安市|