單目錄下多文件 makefile編寫
makefile很久就接觸過了,但是一直沒怎么深入的去學習和總結;在項目中我也只是看看makefile或者修改部分語句,全部自己動手寫的話還真沒有;知識在于沉淀,這句說的非常好,所以現在把自己理解的東西,記錄下來,以便后面查閱;
這篇blog要分享的是在單目錄下多文件的makefile編寫,首先說明當前目錄下有多少文件:fun.h fun.c main.c makefile;其中*.c 文件都要依賴 *.h文件;
首先常規編譯:
預處理期:gcc -E -o fun.i fun.c
編譯階段:gcc -S -o fun.s fun.i
匯編階段: gcc -c -o fun.o fun.s
鏈接階段:gcc -o main fun.o main.o
這就是gcc的各個編譯階段(頭文件在當前目錄下,會直接搜索到),下面用makefile來編譯下;
第一版的makefile:
[cpp] view plaincopy
- CC = gcc
- CFLAGS = -g -Wall
- objects = main.o fun.o
- main:main.o fun.o
- $(CC) -o main main.o fun.o
- main.o:main.c
- $(CC) $(CFLAGS) -c main.c -o main.o
- fun.o:fun.c
- $(CC) $(CFLAGS) -c fun.c -o fun.o
- clean:
- rm -rf $(objects) main
上面第一版就是根據gcc命令行湊成的,第二版將會使用makefile的自動推導功能;
比如:fun.o:fun.c
$(CC) $(CFLAGS) -c fun.c -o fun.o
當已知目的文件為 fun.o時,makefile會自動推導出依賴文件為fun.c并且編譯規則也會自動推導,所以只需要注明依賴的頭文件就可以;可以利用makefile自動推導特點簡化為:fun.o:fun.h就可以了;
第二版makefile
[cpp] view plaincopy
- CC = gcc
- CFLAGS = -g -Wall
- objects = main.o fun.o
- main:$(objects)
- $(CC) -o main $(objects)
- main.o:fun.h
- fun.o:fun.h
- clean:
- rm -rf $(objects) main
其實上面的makefile已經寫的非常簡潔了,如果還需要簡單的話可以再簡化些:
[cpp] view plaincopy
- CC = gcc
- CFLAGS = -g -Wall
- objects = main.o fun.o
- main:$(objects)
- #$(objects):fun.h //可以有,也可以沒有
- PHONY:clean
- clean:
- rm -rf $(objects) main
其中.PHONY是用來說明后面的名稱不是一個文件,主要用來區分同名文件(如果有一個文件名為clean文件,那么clean:下的規則就會無效);
轉載請注明作者和原文出處,原文地址:http://blog.csdn.net/yuzhihui_no1/article/details/44808441
若有不正確之處,望大家指正,共同學習!謝謝!!!
RFID管理系統集成商 RFID中間件 條碼系統中間層 物聯網軟件集成