makefile note

源自:https://blog.csdn.net/haoel/article/details/2886

第一章

何為makefile

  • makefile就像一個(gè)Shell腳本一樣,其中也可以執(zhí)行操作系統(tǒng)的命令
  • makefile帶來(lái)的好處就是——“自動(dòng)化編譯”,一旦寫(xiě)好,只需要一個(gè)make命令,整個(gè)工程完全自動(dòng)編譯
  • make是一個(gè)命令工具,是一個(gè)解釋makefile中指令的命令工具

編譯鏈接

  • C這類(lèi)編譯語(yǔ)言,首先要把源文件編譯成中間文件,在Windows下也就是 .obj 文件,UNIX下是 .o 文件,這個(gè)動(dòng)作叫做編譯。然后再把大量的中間文件合成執(zhí)行文件,這個(gè)動(dòng)作叫作鏈接
  • 每個(gè)源文件都應(yīng)該對(duì)應(yīng)于一個(gè)中間目標(biāo)文件
  • 鏈接時(shí),主要是鏈接函數(shù)和全局變量
  • 鏈接器并不管函數(shù)所在的源文件,只管函數(shù)的中間目標(biāo)文件
  • 在大多數(shù)時(shí)候,由于源文件太多,編譯生成的中間目標(biāo)文件太多,我們要給中間目標(biāo)文件打個(gè)包,在Windows下是 .lib 文件,在UNIX下就是 .a 文件

編譯規(guī)則

  1. 如果這個(gè)工程沒(méi)有編譯過(guò),那么我們的所有C文件都要編譯并被鏈接。
  2. 如果這個(gè)工程的某幾個(gè)C文件被修改,那么我們只編譯被修改的C文件,并鏈接目標(biāo)程序。
  3. 如果這個(gè)工程的頭文件被改變了,那么我們需要編譯引用了這幾個(gè)頭文件的C文件,并鏈接目標(biāo)程序。

Makefile核心規(guī)則

target : prerequisites
    command
  • target也就是一個(gè)目標(biāo)文件,還可以是一個(gè)標(biāo)簽(Label),對(duì)于標(biāo)簽這種特性,在后續(xù)的“偽目標(biāo)”章節(jié)中會(huì)有敘述
  • prerequisites就是,要生成那個(gè)target所需要的文件或是目標(biāo)
  • command也就是make需要執(zhí)行的命令

這是一個(gè)文件的依賴(lài)關(guān)系,也就是說(shuō),target這一個(gè)或多個(gè)的目標(biāo)文件依賴(lài)于prerequisites中的文件,其生成規(guī)則定義在command中。
說(shuō)白一點(diǎn)就是,prerequisites中如果有一個(gè)以上的文件比target文件要新的話,command所定義的命令就會(huì)被執(zhí)行。
這就是Makefile中最核心的內(nèi)容

command可以是任意的Shell命令,說(shuō)白了,你可以用它做任意的事!

第一個(gè)makefile

    edit : main.o kbd.o command.o display.o /
           insert.o search.o files.o utils.o
            cc -o edit main.o kbd.o command.o display.o /
                       insert.o search.o files.o utils.o

    main.o : main.c defs.h
            cc -c main.c
    kbd.o : kbd.c defs.h command.h
            cc -c kbd.c
    command.o : command.c defs.h command.h
            cc -c command.c
    display.o : display.c defs.h buffer.h
            cc -c display.c
    insert.o : insert.c defs.h buffer.h
            cc -c insert.c
    search.o : search.c defs.h buffer.h
            cc -c search.c
    files.o : files.c defs.h buffer.h command.h
            cc -c files.c
    utils.o : utils.c defs.h
            cc -c utils.c
    clean :
            rm edit main.o kbd.o command.o display.o /
               insert.o search.o files.o utils.o
  • 反斜杠(/)是換行符的意思。

筆者認(rèn)為,應(yīng)該是\

  • 我們可以把這個(gè)內(nèi)容保存在文件為“Makefile”或“makefile”的文件中,然后在該目錄下直接輸入命令“make”就可以生成執(zhí)行文件edit
  • 如果要?jiǎng)h除執(zhí)行文件和所有的中間目標(biāo)文件,那么,只要簡(jiǎn)單地執(zhí)行一下“make clean”就可以了。

在定義好依賴(lài)關(guān)系后,后續(xù)的那一行定義了如何生成目標(biāo)文件的操作系統(tǒng)命令,一定要以一個(gè)Tab鍵作為開(kāi)頭。
記住,make并不管命令是怎么工作的,他只管執(zhí)行所定義的命令。
make會(huì)比較targets文件和prerequisites文件的修改日期,如果prerequisites文件的日期要比targets文件的日期要新,或者target不存在的話,那么,make就會(huì)執(zhí)行后續(xù)定義的命令。

這里要說(shuō)明一點(diǎn)的是,clean不是一個(gè)文件,它只不過(guò)是一個(gè)動(dòng)作名字,有點(diǎn)像C語(yǔ)言中的lable一樣,其冒號(hào)后什么也沒(méi)有,那么,make就不會(huì)自動(dòng)去找文件的依賴(lài)性,也就不會(huì)自動(dòng)執(zhí)行其后所定義的命令。要執(zhí)行其后的命令,就要在make命令后明顯得指出這個(gè)lable的名字。
這樣的方法非常有用,我們可以在一個(gè)makefile中定義不用的編譯或是和編譯無(wú)關(guān)的命令,比如程序的打包,程序的備份

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容