make 学习体会(一)
生活随笔
收集整理的這篇文章主要介紹了
make 学习体会(一)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
在對makefile進行了部分學習后,感覺到還是多看看簡短的例子比較好。
發現下面這個網站講得很好:
http://www.cs.colby.edu/maxwell/courses/tutorials/maketutor/
hellomake.c:
復制代碼 #include? int main() { // call a function in another file myPrintHelloMake();
return(0); } 復制代碼 hellofunc.c:
復制代碼 #include? #include?
void myPrintHelloMake(void) { printf("Hello makefiles!\n"); return; } 復制代碼 hellomake.h:
/* example include file */ void myPrintHelloMake(void); 第一個 makefile的例子:
hellomake: hellomake.c hellofunc.c gcc -o hellomake hellomake.c hellofunc.c -I. hellomake 是規則名;它的前提條件是:hellomake.c 和 hellofunc.c。
在此規則中,我們要執行的片段是: gcc -o hellomake hellomake.c hellofunc.c -I
第二個 makefile的例子:
CC=gcc CFLAGS=-I.
hellomake: hellomake.o hellofunc.o $(CC) -o hellomake hellomake.o hellofunc.o -I. 此處定義了 變量 cc 和 CFLAGS , 這也是很多 makefile中很常見的兩個變量。
此時,規則 hellomake 依賴于兩個目標文件 hellomake.o 和 hellofunc.o ,
而且這里有一個隱含的依賴關系:
hellomake.o 來自于對 hellomake.c 的編譯
hellofunc.o 來自于 對 hellofunc.c 的編譯
由于為了生成 hellomake,需要 hellomake.o 和 hellofunc.o ,
就意味著實際上需要 hellomake.c 和 hellofunc.c。
$(CC) 就代表了 gcc 命令,此處實際上還尚未使用 CFLAGS 變量。
第三個 makefile例子:
復制代碼 CC=gcc CFLAGS=-I. DEPS = hellomake.h
%.o: %.c $(DEPS) $(CC) -c -o $@ $< $(CFLAGS)
hellomake: hellomake.o hellofunc.o? gcc -o hellomake hellomake.o hellofunc.o -I. 復制代碼 %.o: 規則表明:每一個 .o 文件,都是依賴于 同名的 .c 文件,和 DEPS 所定義的頭文件。
具體為了生成此 .o 文件,需要進行編譯動作:
$(CC) -c -o $@ $< $(CFLAGS)
其中 $(CC) 和 -c -o 都不用解釋了。
$@表示的就是 冒號左邊的內容,即某個.o 文件。
$<表示的就是 冒號右邊的第一個參數,即此同名的.c 文件。
$(CFLAGS) 在這里就是 -I。
第四個 makefile例子:
復制代碼 CC=gcc CFLAGS=-I. DEPS = hellomake.h OBJ = hellomake.o hellofunc.o?
%.o: %.c $(DEPS) $(CC) -c -o $@ $< $(CFLAGS)
hellomake: $(OBJ) gcc -o $@ $^ $(CFLAGS) 復制代碼 同上個例子相比,它又定義兩個 OBJ變量。
hellomake 依賴于 OBJ變量所指代的目標文件,
gcc -o $@ $^ $(CFLAGS) 中,其他的都不用再解釋了。
$^ 是冒號右邊的值,這里就是 $(OBJ),也就是 hellomake.o, hellofunc.o。
第五個 makefile例子:
復制代碼 IDIR =../include CC=gcc CFLAGS=-I$(IDIR)
ODIR=obj LDIR =../lib
LIBS=-lm
_DEPS = hellomake.h DEPS = $(patsubst %,$(IDIR)/%,$(_DEPS))
_OBJ = hellomake.o hellofunc.o? OBJ = $(patsubst %,$(ODIR)/%,$(_OBJ))
$(ODIR)/%.o: %.c $(DEPS) $(CC) -c -o $@ $< $(CFLAGS)
hellomake: $(OBJ) gcc -o $@ $^ $(CFLAGS) $(LIBS)
.PHONY: clean
clean: rm -f $(ODIR)/*.o *~ core $(INCDIR)/*~? 復制代碼 這里面 IDIR,LDIR,ODIR 分別指定了 頭文件/庫文件/輸出目標文件的目錄。
來看這一句:
DEPS = $(patsubst %,$(IDIR)/%,$(_DEPS)) patsubst 是一個 函數,它會把所有 % 所代表的文件字符串,改變為 頭文件目錄下的 文件字符串。
第三個參數 $(_DEPS)指明了這個 函數的作用范圍。
OBJ = $(patsubst %,$(ODIR)/%,$(_OBJ)) 的作法與此類似。
其他的,也沒有什么可以說的了,但是 這里有一個偽規則 clean。它是沒有前提條件的。
rm -f $(ODIR)/*.o *~ core $(INCDIR)/*~ 中,
*~ , 我猜測代表的是 所有沒有擴展名的文件。core 指代的是程序出錯時生成的 core 文件。
標簽: Makefile, example
本文轉自健哥的數據花園博客園博客,原文鏈接:http://www.cnblogs.com/gaojian/archive/2012/09/17/2688165.html,如需轉載請自行聯系原作者
發現下面這個網站講得很好:
http://www.cs.colby.edu/maxwell/courses/tutorials/maketutor/
hellomake.c:
復制代碼 #include? int main() { // call a function in another file myPrintHelloMake();
return(0); } 復制代碼 hellofunc.c:
復制代碼 #include? #include?
void myPrintHelloMake(void) { printf("Hello makefiles!\n"); return; } 復制代碼 hellomake.h:
/* example include file */ void myPrintHelloMake(void); 第一個 makefile的例子:
hellomake: hellomake.c hellofunc.c gcc -o hellomake hellomake.c hellofunc.c -I. hellomake 是規則名;它的前提條件是:hellomake.c 和 hellofunc.c。
在此規則中,我們要執行的片段是: gcc -o hellomake hellomake.c hellofunc.c -I
第二個 makefile的例子:
CC=gcc CFLAGS=-I.
hellomake: hellomake.o hellofunc.o $(CC) -o hellomake hellomake.o hellofunc.o -I. 此處定義了 變量 cc 和 CFLAGS , 這也是很多 makefile中很常見的兩個變量。
此時,規則 hellomake 依賴于兩個目標文件 hellomake.o 和 hellofunc.o ,
而且這里有一個隱含的依賴關系:
hellomake.o 來自于對 hellomake.c 的編譯
hellofunc.o 來自于 對 hellofunc.c 的編譯
由于為了生成 hellomake,需要 hellomake.o 和 hellofunc.o ,
就意味著實際上需要 hellomake.c 和 hellofunc.c。
$(CC) 就代表了 gcc 命令,此處實際上還尚未使用 CFLAGS 變量。
第三個 makefile例子:
復制代碼 CC=gcc CFLAGS=-I. DEPS = hellomake.h
%.o: %.c $(DEPS) $(CC) -c -o $@ $< $(CFLAGS)
hellomake: hellomake.o hellofunc.o? gcc -o hellomake hellomake.o hellofunc.o -I. 復制代碼 %.o: 規則表明:每一個 .o 文件,都是依賴于 同名的 .c 文件,和 DEPS 所定義的頭文件。
具體為了生成此 .o 文件,需要進行編譯動作:
$(CC) -c -o $@ $< $(CFLAGS)
其中 $(CC) 和 -c -o 都不用解釋了。
$@表示的就是 冒號左邊的內容,即某個.o 文件。
$<表示的就是 冒號右邊的第一個參數,即此同名的.c 文件。
$(CFLAGS) 在這里就是 -I。
第四個 makefile例子:
復制代碼 CC=gcc CFLAGS=-I. DEPS = hellomake.h OBJ = hellomake.o hellofunc.o?
%.o: %.c $(DEPS) $(CC) -c -o $@ $< $(CFLAGS)
hellomake: $(OBJ) gcc -o $@ $^ $(CFLAGS) 復制代碼 同上個例子相比,它又定義兩個 OBJ變量。
hellomake 依賴于 OBJ變量所指代的目標文件,
gcc -o $@ $^ $(CFLAGS) 中,其他的都不用再解釋了。
$^ 是冒號右邊的值,這里就是 $(OBJ),也就是 hellomake.o, hellofunc.o。
第五個 makefile例子:
復制代碼 IDIR =../include CC=gcc CFLAGS=-I$(IDIR)
ODIR=obj LDIR =../lib
LIBS=-lm
_DEPS = hellomake.h DEPS = $(patsubst %,$(IDIR)/%,$(_DEPS))
_OBJ = hellomake.o hellofunc.o? OBJ = $(patsubst %,$(ODIR)/%,$(_OBJ))
$(ODIR)/%.o: %.c $(DEPS) $(CC) -c -o $@ $< $(CFLAGS)
hellomake: $(OBJ) gcc -o $@ $^ $(CFLAGS) $(LIBS)
.PHONY: clean
clean: rm -f $(ODIR)/*.o *~ core $(INCDIR)/*~? 復制代碼 這里面 IDIR,LDIR,ODIR 分別指定了 頭文件/庫文件/輸出目標文件的目錄。
來看這一句:
DEPS = $(patsubst %,$(IDIR)/%,$(_DEPS)) patsubst 是一個 函數,它會把所有 % 所代表的文件字符串,改變為 頭文件目錄下的 文件字符串。
第三個參數 $(_DEPS)指明了這個 函數的作用范圍。
OBJ = $(patsubst %,$(ODIR)/%,$(_OBJ)) 的作法與此類似。
其他的,也沒有什么可以說的了,但是 這里有一個偽規則 clean。它是沒有前提條件的。
rm -f $(ODIR)/*.o *~ core $(INCDIR)/*~ 中,
*~ , 我猜測代表的是 所有沒有擴展名的文件。core 指代的是程序出錯時生成的 core 文件。
標簽: Makefile, example
本文轉自健哥的數據花園博客園博客,原文鏈接:http://www.cnblogs.com/gaojian/archive/2012/09/17/2688165.html,如需轉載請自行聯系原作者
總結
以上是生活随笔為你收集整理的make 学习体会(一)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ssm整合(基于xml配置方式)
- 下一篇: 【单页应用】全局控制器app应该干些什么