Makefile
cmd:
- g++
相信在linux下編程的沒有不知道makefile的,剛開始學習linux平台下的東西,了解了下makefile的制作,覺得有點東西可以記錄下。
下面是一個極其簡單的例子:
現在我要編譯一個Hello world,需要如下三個文件:
1. print.h
#include<stdio.h>
void printhello();
2. print.c
1 #include"print.h" 2 void printhello() 3 { 4 printf("Hello, world\n"); 5 }
3. main.c
1 #include "print.h" 2 int main(void) 3 { 4 printhello(); 5 return 0; 6 }
好了,很簡單的程序了。如果我們想要編譯成功需要哪些步驟呢?
我認為在這里需要理解的就兩步:
# 為每一個 *.c文件生成 *o文件。
# 連接每一個*o文件,生成可執行文件。
下面的makefile 就是根據這樣的原則來寫的。
一:makefile 雛形:
#makefile的撰寫是基於規則的,當然這個規則也是很簡單的,就是:
#target : prerequisites
command //任意的shell 命令
實例如下:makefile文件內容:
helloworld : main.o print.o #helloword 就是我們要生成的目標 g++ -std=c++11 -o helloworld main.o print.o#shell命令,最前面的一定是一個tab鍵 mian.o : mian.c print.h g++ -std=c++11 -c main.c print.o : print.c print.h g++ -std=c++11 -c print.c clean : rm helloworld main.o print.o
OK,一個簡單的makefile制作完畢,現成我們輸入 make,自動調用Gcc編譯了,輸入 make clean就會刪除 hellowworld mian.o print.o
二:小步改進:
在上面的例子中我們可以發現 main.o print.o 被定義了多處,我們是不是可以向C語言中定義一個宏一樣定義它呢?當然可以:
修改后的文件:
1 objects = main.o print.o #應該叫變量的聲明更合適 2 helloworld : $(objects) #聲明了變量以后使用就要$()了 3 g++ -std=c++11 -o helloworld$(objects) 4 mian.o : mian.c print.h 5 g++ -std=c++11 -c main.c 6 print.o : print.c print.h 7 g++ -std=c++11 -c print.c 8 9 clean : 10 rm helloworld $(objects)
修改完畢,這樣使用了變量的話在很多文件的工程中就能體現出方便性了。
三:再進一步:
再看一下,為沒一個*.o文件都寫一句gcc -c main.c是不是顯得多余了,
能不能把它干掉?而且 main.c 和print.c都需要print.h,為每一個都寫上是
不是多余了,能不能再改進?
能,當然能了:makefile內容:
1 objects = main.o print.o 2 helloworld : $(objects) 3 g++ -std=c++11 -o helloworld$(objects) 4 5 $(objects) : print.h # 都依賴print.h 6 mian.o : mian.c #干掉了gcc -c main.c 讓Gun make自動推導了。 7 print.o : print.c 8 clean : 9 rm helloworld $(objects)