編譯多個c檔案一般有兩個功能,一個是每個c檔案都有main函數,就是說每個c檔案的可執行檔案是獨立的,各自是各自的;第二個是多個c檔案用來編譯成一個可執行檔案。
首先說第一個,内容如下,這個makefile是為了編譯opencv代碼的。
[cpp] view plain copy
- CFLAGS= -g -O3 `pkg-config opencv --cflags`
- LIBS = `pkg-config opencv --libs`
- C_SRC = $(wildcard *.c)
- C_OBJ = $(patsubst %c, %o, $(C_SRC))
- CPP_SRC = $(wildcard *.cpp)
- CPP_OBJ = $(patsubst %cpp, %o, $(CPP_SRC))
- .PHONY:all clean
- all:$(CPP_OBJ) $(C_OBJ)
- .c.o:
- gcc $(CFLAGS) -o [email protected] $< $(LIBS)
- .cpp.o:
- g++ $(CFLAGS) -o [email protected] $< $(LIBS)
- clean:
- rm *~ *.o -f
cflags 和 libs就不說了, c_src和c_obj中,$(wildcard *.c, *.cpp, ***/*.c)是為了找出目錄和指定目錄下所有的字尾為c和cpp的檔案,這個功能也可以使用c_src=$(shell echo *.c)實作。 $(patsubst %cpp, %o, $(CPP_SRC))中是為了将所有的cpp檔案的字尾替換為o檔案,這個功能也可以通過CPP_OBJ=$(CPP_SRC:%.c=%.o)實作 PHONY是僞目标 all後是要生成的所有目标檔案 最後的.c.o和.cpp.o這兩個,是為了通配編譯c字尾和cpp字尾檔案的規則。 這樣即可編譯目錄下所有的源檔案,為各自生成可執行檔案了。 Makefile編譯目錄下多個檔案
參考網址:http://forkhope.diandian.com/post/2012-10-12/40040828841 http://blog.csdn.net/jernymy/article/details/6401065
http://hi.baidu.com/zengzhaonong/item/f07c81e1da455210585dd89a
第二個是編譯所有c檔案,生成一個目标檔案。有了上一個的基礎,第二個目标的例子為 [cpp] view plain copy
- 01 CC = gcc
- 02 LD = gcc
- 03 CFLAGS = -Wall -c -Dgliethttp -I../include -L lib_path
- 04 LDFLAGS = -lpthread
- 05
- 06 SRCS = $(wildcard *.c source/*.c)
- 07 OBJS = $(patsubst %c, %o, $(SRCS))
- 08 TARGET = gliethttp
- 09
- 10 .PHONY: all clean
- 11
- 12 all: $(TARGET)
- 13
- 14 $(TARGET): $(OBJS)
- 15 $(LD) $(LDFLAGS) -o [email protected] $^
- 16
- 17 %o: %c
- 18 $(CC) $(CFLAGS) -o [email protected] $<
- 19
- 20 clean:
- 21 rm -f *.o $(TARGET)
Makfile相關函數說明:
1、wildcard : 擴充通配符
2、notdir : 去除路徑
3、patsubst :替換通配符
例子:
建立一個測試目錄,在測試目錄下建立一個名為sub的子目錄
$ mkdir test
$ cd test
$ mkdir sub
在test下,建立a.c和b.c2個檔案,在sub目錄下,建立sa.c和sb.c2 個檔案
建立一個簡單的Makefile
src=$(wildcard *.c ./sub/*.c)
dir=$(notdir $(src))
obj=$(patsubst %.c,%.o,$(dir) )
all:
@echo $(src)
@echo $(dir)
@echo $(obj)
@echo "end"
執行結果分析:
第一行輸出:
a.c b.c ./sub/sa.c ./sub/sb.c
wildcard把 指定目錄 ./ 和 ./sub/ 下的所有字尾是c的檔案全部展開。
第二行輸出:
a.c b.c sa.c sb.c
notdir把展開的檔案去除掉路徑資訊
第三行輸出:
a.o b.o sa.o sb.o
在$(patsubst %.c,%.o,$(dir) )中,patsubst把$(dir)中的變量符合字尾是.c的全部替換成.o,
任何輸出。
或者可以使用
obj=$(dir:%.c=%.o)
效果也是一樣的。
這裡用到makefile裡的替換引用規則,即用您指定的變量替換另一個變量。
它的标準格式是
$(var:a=b) 或 ${var:a=b}
它的含義是把變量var中的每一個值結尾用b替換掉a