C++關於Makefile的詳解含通用模板

今天小編就爲大家分享一篇關於C++關於Makefile的詳解含通用模板,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧

介紹

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 helloworld
main.o: main.cpp test.h
  g++ -c main.cpp -o main.o
test.o: test.cpp test.h
  g++ -c test.cpp -o test.o
clean:
  rm *.o helloworld

3.2 makefile中使用註釋,變量和函數

註釋:

    行前面加"#"號,如#g++ main.o test.o -o helloworld  表示註釋了該行

變量:

  •     用=定義一個變量,並且賦值(等號兩邊可以加空格)
  •     用+=追加字符串
  •     用$(A)來取得變量的值

例: 

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 = helloworld
GCC = 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 = helloworld
GCC = g++
SUBDIR = src lib
CPP_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++項目,歡迎收藏

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對神馬文庫的支持。如果你想了解更多相關內容請查看下面相關鏈接

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章