一個(gè)簡單的makefile示例

現(xiàn)在我要編譯一個(gè)Hello world,需要如下三個(gè)文件:

1. print.h

 #includevoid printhello();

2. print.c

#include"print.h"

void printhello(){

printf("Hello, world\n");

}

3. main.c

#include "print.h"

int main(void){

printhello();

return 0;

}

好了,很簡單的程序了。如果我們想要編譯成功需要哪些步驟呢?

我認(rèn)為在這里需要理解的就兩步:

#? 為每一個(gè) *.c文件生成 *o文件。

#? 連接每一個(gè)*o文件,生成可執(zhí)行文件。

下面的makefile 就是根據(jù)這樣的原則來寫的。

一:makefile 雛形:

#makefile的撰寫是基于規(guī)則的,當(dāng)然這個(gè)規(guī)則也是很簡單的,就是:

#target : prerequisites

command  //任意的shell 命令

實(shí)例如下:

makefile:

helloworld : main.o print.o #helloword 就是我們要生成的目標(biāo)

# main.o print.o是生成此目標(biāo)的先決條件

gcc -o helloworld main.o print.o#shell命令,最前面的一定是一個(gè)tab鍵

mian.o : mian.c print.h

gcc -c main.c

print.o : print.c print.h

gcc -c print.c

clean :

rm helloworld main.o print.o

OK,一個(gè)簡單的makefile制作完畢,現(xiàn)成我們輸入 make,自動(dòng)調(diào)用Gcc編譯了,

輸入 make clean就會(huì)刪除 hellowworld mian.o print.o

二:小步改進(jìn):

在上面的例子中我們可以發(fā)現(xiàn) main.o print.o 被定義了多處,

我們是不是可以向C語言中定義一個(gè)宏一樣定義它呢?當(dāng)然可以:

makefile:

objects =? main.o print.o #應(yīng)該叫變量的聲明更合適

helloworld : $(objects) //聲明了變量以后使用就要$()了

gcc -o helloworld$(objects)

mian.o : mian.c print.h

gcc -c main.c

print.o : print.c print.h

gcc -c print.c

clean :

rm helloworld $(objects)

修改完畢,這樣使用了變量的話在很多文件的工程中就能體現(xiàn)出方便性了。

三:再進(jìn)一步:

再看一下,為沒一個(gè)*.o文件都寫一句gcc -c main.c是不是顯得多余了,

能不能把它干掉?而且 main.c 和print.c都需要print.h,為每一個(gè)都寫上是

不是多余了,能不能再改進(jìn)?

能,當(dāng)然能了:

makefile:

objects =? main.o print.o

helloworld : $(objects)

gcc -o helloworld$(objects)

$(objects) : print.h # 都依賴print.h

mian.o : mian.c? #干掉了gcc -c main.c 讓Gun make自動(dòng)推導(dǎo)了。

print.o : print.c

clean :

rm helloworld $(objects)

好了,一個(gè)簡單的makefile就這樣完畢了,簡單吧。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容