《LINUX教程:Makefile簡單入門教程》要點:
本文介紹了LINUX教程: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教程,盡在維易PHP學院專欄。歡迎交流《LINUX教程:Makefile簡單入門教程》!