makefile实例【转载】
/*?main.c?*/?
#include?<mytool1.h>?
#include?<mytool2.h>?
int?main(int?argc,char?**argv)?
{?
mytool1_print("hello");?
mytool2_print("hello");?
}?
/*?mytool1.h?*/?
#ifndef?_MYTOOL_1_H?
#define?_MYTOOL_1_H?
void?mytool1_print(char?*print_str);?
#endif?
/*?mytool1.c?*/?
#include?<mytool1.h>?
void?mytool1_print(char?*print_str)?
{?
printf("This?is?mytool1?print?%s\n",print_str);?
}?
/*?mytool2.h?*/?
#ifndef?_MYTOOL_2_H?
#define?_MYTOOL_2_H?
void?mytool2_print(char?*print_str);?
#endif?
/*?mytool2.c?*/?
#include?<mytool2.h>?
void?mytool2_print(char?*print_str)?
{?
printf("This?is?mytool2?print?%s\n",print_str);?
}?
當(dāng)然由于這個(gè)程序是很短的我們可以這樣來編譯
gcc -c main.c -I.
gcc -c mytool1.c -I.
gcc -c mytool2.c -I.
gcc -o main main.o mytool1.o mytool2.o
因?yàn)槲覀冊(cè)诔绦蛑惺褂昧宋覀冏约旱?個(gè)頭文件,而在包含這2個(gè)頭文件的時(shí)候,我們使用的是<> 這樣編譯器在編譯的時(shí)候會(huì)去系統(tǒng)默認(rèn)的頭文件路徑找我們的2個(gè)頭文件,由于我們的2個(gè)頭文件不在系統(tǒng)能夠的缺省路徑下面,所以我們自己擴(kuò)展系統(tǒng)的缺省路徑,為此我們使用了-I.選項(xiàng),表示將系統(tǒng)缺省的頭文件路徑擴(kuò)展到當(dāng)前路徑.
這樣的話我們也可以產(chǎn)生main程序,而且也不是很麻煩.但是考慮一下如果有一天我們修改了其中的一個(gè)文件(比如說mytool1.c)那么我們難道還要重新輸入上面的命令?也許你會(huì)說,這個(gè)很容易解決啊,我寫一個(gè)SHELL腳本,讓她幫我去完成不就可以了.是的對(duì)于這個(gè)程序來說,是可以起到作用的.但是當(dāng)我們把事情想的更復(fù)雜一點(diǎn),如果我們的程序有幾百個(gè)源程序的時(shí)候,難道也要編譯器重新一個(gè)一個(gè)的去編譯?
為此,聰明的程序員們想出了一個(gè)很好的工具來做這件事情,這就是make.我們只要執(zhí)行一下make,就可以把上面的問題解決掉.在我們執(zhí)行make之前,我們要先編寫一個(gè)非常重要的文件.--Makefile.對(duì)于上面的那個(gè)程序來說,可能的一個(gè)Makefile的文件是:
# 這是上面那個(gè)程序的Makefile文件
main:main.o mytool1.o mytool2.o
gcc -o main main.o mytool1.o mytool2.o
main.o:main.c mytool1.h mytool2.h
gcc -c main.c -I.
mytool1.o:mytool1.c mytool1.h
gcc -c mytool1.c -I.
mytool2.o:mytool2.c mytool2.h
gcc -c mytool2.c -I.
有了這個(gè)Makefile文件,不管我們什么時(shí)候修改了源程序當(dāng)中的什么文件,我們只要執(zhí)行make命令,我們的編譯器都只會(huì)去編譯和我們修改的文件有關(guān)的文件,其它的文件她連理都不想去理的.
下面我們學(xué)習(xí)Makefile是如何編寫的.
在Makefile中也#開始的行都是注釋行.Makefile中最重要的是描述文件的依賴關(guān)系的說明.一般的格式是:
target: components
TAB rule
第一行表示的是依賴關(guān)系.第二行是規(guī)則.
main:main.o mytool1.o mytool2.o
表示我們的目標(biāo)(target)main的依賴對(duì)象(components)是main.o mytool1.o mytool2.o 當(dāng)倚賴的對(duì)象在目標(biāo)修改后修改的話,就要去執(zhí)行規(guī)則一行所指定的命令.就象我們的上面那個(gè)Makefile第三行所說的一樣要執(zhí)行 gcc -o main main.o mytool1.o mytool2.o 注意規(guī)則一行中的TAB表示那里是一個(gè)TAB鍵
Makefile有三個(gè)非常有用的變量.分別是$@,$^,$<代表的意義分別是:
$@--目標(biāo)文件,$^--所有的依賴文件,$<--第一個(gè)依賴文件.
如果我們使用上面三個(gè)變量,那么我們可以簡(jiǎn)化我們的Makefile文件為:
# 這是簡(jiǎn)化后的Makefile
# 記得我們的優(yōu)化和警告選項(xiàng)嗎?
main:main.o mytool1.o mytool2.o
gcc -O2 -o $@ $^
main.o:main.c mytool1.h mytool2.h
gcc -O2 -Wall -c $< -I.
mytool1.o:mytool1.c mytool1.h
gcc -O2 -Wall -c $< -I.
mytool2.o:mytool2.c mytool2.h
gcc -O2 -Wall -c $< -I.
經(jīng)過簡(jiǎn)化后我們的Makefile是簡(jiǎn)單了一點(diǎn),不過人們有時(shí)候還想簡(jiǎn)單一點(diǎn)(唉,看來程序員都是大懶鬼哦 ^_^). 為此make又有了一些缺省的規(guī)則
這里我們學(xué)習(xí)一個(gè)Makefile的缺省規(guī)則
.c.o:
???? gcc -c $<
這個(gè)規(guī)則表示所有的 .o文件都是依賴與其相應(yīng)的.c文件的.例如mytool.o依賴于mytool.c這樣Makefile還可以變?yōu)?
# 這是再一次簡(jiǎn)化后的Makefile
main:main.o mytool1.o mytool2.o
gcc -o $@ $^
.c.o:
???? gcc -c $< -I.
如果你還是嫌這樣太麻煩的話,我們還可以進(jìn)行一些簡(jiǎn)化工作.為此我們來學(xué)習(xí)一下Makefile的一些缺省的宏定義 Makefile一般有很多很多的宏,我們這里只是學(xué)習(xí)幾個(gè)常用的宏.
CC 表示我們的編譯器名稱,缺省值為cc.
CFLAGS 表示我們想給編譯器的編譯選項(xiàng)
LDLIBS 表示我們的在編譯的時(shí)候編譯器的連接庫選項(xiàng).(我們的這個(gè)程序中還用不到這個(gè)選項(xiàng))
使用了上面的宏后我們的Makefile可以是
CC=gcc
CFLAGS=-g -Wall -O2 -I.
main:main.o mytool1.o mytool2.o
.c.o:
???? CC CFLAGS $<
好了,我們的Makefile 也差不多了,可以輸入make -f Makefile來運(yùn)行Makefile文件。如果想知道更多的關(guān)于Makefile規(guī)則可以查看相應(yīng)的文檔. 使用(man make 或者是info make)
其實(shí),對(duì)于小的工程可以自己建立?? MAKEFILE?? ,要是大的工程的話,最好使用AUTOMAKE?? 等工具,相當(dāng)方便。
?
?
轉(zhuǎn)載于:https://www.cnblogs.com/kakaliush/archive/2010/05/14/1735339.html
總結(jié)
以上是生活随笔為你收集整理的makefile实例【转载】的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: WF4.0 应用篇(四) IActivi
- 下一篇: 51单片机常用寄存器速查