linux makefile教程,Makefile简单入门教程
一、簡介
make命令執行時,需要一個 Makefile 文件,以告訴make命令需要怎么樣的去編譯和鏈接程序(簡單將:管理工程的文件,決定先編譯哪些文件,編譯順序)。
二、編寫規則:
目標1:目標依賴? 然后回車+tab鍵
命令;
目標2:目標依賴? 然后回車+tab鍵
命令;
...
目標n:目標依賴? 然后回車+tab鍵
命令;
注意:命令必須是tab鍵開頭的。
三、Makefile演進
1、一個項目有main.c/a.c/a.h/b.c/b.h五個文件;main.c包含a.h和b.h并使用相關函數;然后建立一個新的Makefile文件,內容如下:
main:a.o b.o
gcc -o main a.o b.o
a.o:a.c
gcc -c a.c -o a.o
b.o:b.c
gcc -c b.c -o b.o
2、Makefile升級1
采用makefile變量:想用就用,沒有類型,不需要定義(引用變量使用$(obj)來包含更多.o文件)
方法:obj:=a.o b.o
那么上面的Makefile程序升級如下:
obj:=a.o b.o
main:$(obj)
gcc -o main a.o b.o
a.o:a.c
gcc -c a.c -o a.o
b.o:b.c
gcc -c b.c -o b.o
3、Makefile升級2
經過以上兩個makefile的編譯,項目執行是成功的,但是如果main.c需要引用更多文件中的函數時,是否要填寫那么多的編譯命令嗎?顯然這個方法不可取。
改進:makefile特殊變量和自動推導功能
知識點說明:
$@? 代表目標名,
$^? 代表依賴文件
%? 代表任意字符
%.o? 代表任意.o文件
%.c? 代表任意.c文件
以上Makefile升級如下:
obj:=a.o b.o
main:$(obj)
gcc -o main $(obj)
%.o:%c? ? ? #注釋:模式通配,自動將.c文件編譯成.o文件
gcc -o $@ -c $^? ? #注釋:通配符
clean:
rm -rf *.o main
4、Makefile升級3
exe=main? ? ? #注釋:最后的編譯結果名字
obj:=main.o a.o b.o c.o? ?#注釋:依賴文件
all:$(obj)
gcc -o $(exe) $(obj)
%.o:%.c
gcc -c $^ -o $@
clean:
rm -rf $(obj) $(exe)
以上程序看似沒有什么問題的,但是clean有點瑕疵,要是也有一個文件叫clean那怎么辦?如果make clean就沒辦法執行這條命令。
5、Makefile升級4
使用偽目標.PHONY來解決clean瑕疵問題,升級Makefile如下:
exe:=main
obj:=main.o a.o b.o c.o
all:$(obj)
gcc -o $(exe) $(obj)
%.o:%.c
gcc -c $^ -o $@
.PHONY:clean? ? ?#注釋:聲明clean是偽目標
clean:
rm -rf $(obj) $(exe)
注釋#.PHONY:clean聲明偽目標,避免當前目錄存在名字為clean文件的時候命令不能執行的情況
6、Makefile升級5
有時使用的編譯器可能是g++、gcc甚至是arm-linux-gcc。為了方便統一管理,最好開頭定義一個變量來代表編輯器,然后在gcc命令上變成$(CC):
Makefile升級如下:
CC:=gcc? ? #注釋:定義一個變量,表示當前編輯器為gcc
exe:=main
obj:=main.o a.o b.o c.o
all:$(obj)
$(CC) -o $(exe) $(obj)
%.o:%.c
$(CC) -c $^ -o $@
.PHONY:clean
clean:
rm -rf $(obj) $(exe)
基本上現在的Makefie可以編輯很多普通的程序了。秩序要對Makefile的文件名適當稍加修改即可。如果在比較大型的程序里面寫Makefile會相對知識點多一點,比如添加靜態庫、動態庫、線程等等;后續再做升級。
推薦一本書:GNU make中文手冊(翻譯整理:徐海兵)
總結
以上是生活随笔為你收集整理的linux makefile教程,Makefile简单入门教程的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: activity与service 使用H
- 下一篇: 转: vim 的编辑格式设置