簡單makefile示例

Makefile

cmd:linux

- g++c++

 

相信在linux下編程的沒有不知道makefile的,剛開始學習linux平臺下的東西,瞭解了下makefile的製做,以爲有點東西能夠記錄下。shell


下面是一個極其簡單的例子:
如今我要編譯一個Hello world,須要以下三個文件:
1. print.h編程

#include<stdio.h>  
void printhello();  

 

2. print.cide

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 就是根據這樣的原則來寫的。ui

 

一:makefile 雛形:

 
#makefile的撰寫是基於規則的,固然這個規則也是很簡單的,就是:
#target : prerequisites 
  command  //任意的shell 命令spa

實例以下:makefile文件內容:c++11

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.ocode


二:小步改進:


在上面的例子中咱們能夠發現 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)  
相關文章
相關標籤/搜索