介紹
Makefile是一個規定了怎么去編譯和鏈接程序的腳本文件,在執行make命令時會執行該文件,window環境下的IDE,如visual studio已經集成了該功能,不需要關心程序的編譯規則,在linux下做C/C++開發時經常用到,說到這里首先要知道一個工具make。
make是一個解釋Makefile中指令的命令工具,常見的IDE都集成了這個工具。目前centos 7.3 GNU的make版本是3.82
規則
目標文件:依賴文件
[Tab]系統指令1 (注意:系統指令前必須有tab)
使用
3.1 簡單使用
現有文件main.cpp test.cpp test.h三個文件,說些Makefile實現增量編譯(當其中有一個文件變化時,重新編譯該文件)
helloworld: main.o test.o g++ main.o test.o -o helloworldmain.o: main.cpp test.h g++ -c main.cpp -o main.otest.o: test.cpp test.h g++ -c test.cpp -o test.oclean: rm *.o helloworld
3.2 makefile中使用注釋,變量和函數
注釋:
行前面加"#"號,如#g++ main.o test.o -o helloworld 表示注釋了該行
變量:
例:
A = src echo $(A) @echo $(A) ##只輸出echo的結果,不顯示執行的命令
特殊變量:
函數:
Makefile中有一些預定義函數,形式:
$(函數名 參數列表)
參數列表:以逗號分隔
函數名和參數之間用空格分開
#獲取當前目錄路徑
PWD = $(shell pwd)
#獲取當前目錄下所有.cpp文件
CXX_SOURCES = $(wildcard *.cpp)
#獲取當前目錄下所有.cpp文件編譯后的所有目標文件.o
CXX_OBJECTS = $(patsubst *.cpp *.o, $(CXX_SOURCES))
3.3 優化3.1中Makefile
EXE = helloworldGCC = g++$(EXE): main.o test.o $(GCC) $^ -o $(EXE)main.o: main.cpp test.h $(GCC) -c $< -o $@test.o: test.cpp test.h $(GCC) -c $< -o $@clean: rm *.o $(EXE)
3.4 優化3.3中Makefile
繼續優化Makefile,添加文件夾,把源碼都放入src和lib文件夾,保持增量編譯,即為Makefile通用模板
EXE = helloworldGCC = g++SUBDIR = src libCPP_SOURCES = $(foreach dir, $(SUBDIR), $(wildcard $(dir)/*.cpp))CPP_OBJECTS = $(patsubst %.cpp, %.o, $(CPP_SOURCES))DEP_FILES = $(patsubst %.o, %.d, $(CPP_OBJECTS))$(EXE): $(CPP_OBJECTS) $(GCC) $(CPP_OBJECTS) -o $@%.o: %.cpp $(GCC) -c -MMD $< -o $@-include $(DEP_FILES)clean: rm $(CPP_OBJECTS) $(EXE)
此Makefile可以作為通用Makefile模板來編譯C/C++項目,歡迎收藏
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對VEVB武林網的支持。
新聞熱點
疑難解答