C和C++混合编程的Makefile的编写!
在項(xiàng)目實(shí)踐中,經(jīng)常遇到C和C++混合編程的情況。
目前的業(yè)務(wù)需求是:
c寫的幾個(gè)文件,和一個(gè)C++文件要整合為一個(gè)動(dòng)態(tài)庫(kù),被C++調(diào)用。而這個(gè)動(dòng)態(tài)庫(kù)的生成過(guò)程中,會(huì)鏈接幾個(gè)基礎(chǔ)的開發(fā)庫(kù),比如libz,libpcre,libm等。
一.C和C++混合編譯動(dòng)態(tài)庫(kù)的Makefile
編寫這樣的Makefile來(lái)生成一個(gè)正確的so庫(kù)很重要,下面是一個(gè)正確的Makefile的寫法:
CC = gcc
C++ = g++
LINK = g++LIBS = -lz -lm -lpcre
#must add -fPIC option
CCFLAGS = $(COMPILER_FLAGS) -c -g -fPIC
C++FLAGS = $(COMPILER_FLAGS) -c -g -fPICTARGET=libad.soINCLUDES = -I. -I../../C++FILES = main.cpp \../../hookmask.cpp
CFILES = cJSON.c ZipCoding.c TransferCoding.c mem_manage.cOBJFILE = $(CFILES:.c=.o) $(C++FILES:.cpp=.o)all:$(TARGET)$(TARGET): $(OBJFILE)$(LINK) $^ $(LIBS) -Wall -fPIC -shared -o $@%.o:%.c$(CC) -o $@ $(CCFLAGS) $< $(INCLUDES)%.o:%.cpp$(C++) -o $@ $(C++FLAGS) $< $(INCLUDES)install:tsxs -i -o $(TARGET)clean:rm -rf $(TARGET)rm -rf $(OBJFILE)
注意:
1.如果LIBS的位置放置不對(duì),這幾個(gè)基礎(chǔ)庫(kù)將不會(huì)編進(jìn)so中。LIBS只應(yīng)該在最后鏈接為so時(shí)才調(diào)用,前面編譯c和cpp文件時(shí)用不到。
2.c源文件放到CFILES宏后面, cpp文件放到C++Files宏后面,第三方庫(kù)放到LIBS宏后面,頭文件的包含路徑放到INCLUDES后面,庫(kù)文件的包含路徑放到使用-L./等表達(dá)式放到LIBS中的開頭即可。
3.這里嚴(yán)格區(qū)分c和cpp文件的目的是,c文件使用gcc編譯,而cpp文件會(huì)使用g++編譯,它們必須嚴(yán)格區(qū)分開。
下面是依據(jù)上面Makefile編譯后得到的正確的截圖
二.全部是C文件編譯的Makefile
如果全是c的幾個(gè)文件來(lái)編譯一個(gè)動(dòng)態(tài)庫(kù),則相應(yīng)的Makefile文件編寫如下:
gcc -g ?cJSON.c ad-module.c -lm -lz -lpcre -Wall -fPIC -shared -o ad_module.so
這里?-lm -lz -lpcre一定要放在-fPIC -shared前面,否則生成的動(dòng)態(tài)庫(kù)不會(huì)包含-lm -lz -lpcre
總結(jié)
以上是生活随笔為你收集整理的C和C++混合编程的Makefile的编写!的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: ATS中用到的sscanf高级用法说明
- 下一篇: 在Ubuntu 14.04和CentOS