在 C++ 中使用 Makefile

2022/08/27 C++

前言

當一個專案變得比較龐大複雜時,使用 Makefile 協助我們決定編譯 C++ 檔案的順序。make 是一個工具程式,透過 makefile 的檔案可以自動化建構軟體。Makefile 是描述程式原始檔和要編譯的標頭檔案之間的關係的檔名。

一般編譯需要將而外引用的函式庫檔案位置附上:

g++ main.cpp function1.cpp function2.cpp -o main

範例程式放在GitHub

若當有超過幾十隻附加檔案時,shell script 編譯逐一的在指令上添加檔案路徑是非常辛苦的一件事。因此才需要透過 Makefile 幫我們管理這些檔案,讓編譯器在編譯的時候知道要處理哪些檔案。並且只編譯更動過的檔案,這意味著若先前已編譯過檔案若之後沒做更動時不會再花時間編譯一次,這動作大幅降低整體編譯的時間。

Makefile 會先執行 all 區段,後面的 hello 是代表相依要被執行的區段。因此會跑到 hello 區段被執行,裏面也有相依的內容 main.o function1.o function2.o,接著第一步會先編譯 main.o 他的相依程式為 main.cpp 並使用 gcc 指令編譯 .o 檔。

all: hello

hello: main.o function1.o function2.o
		g++ main.o function1.o function2.o -o hello

main.o: main.cpp
		g++ -c main.cpp

function1.o: function1.cpp
		g++ -c function1.cpp

function2.o: function2.cpp
		g++ -c function2.cpp

clean:
		rm -rf *o hello

只下 make 指令會執行 makefile 的第一個 target,因此會先進入 all。

Makefile 進階版寫法,提供變數可以省去重複性高的內容並且好管理指令 -c 代表編譯但不進行鏈結的意思 -Wall 代表編譯時顯示所有的警告訊息。

CC=g++
CFLAGS=-c -Wall

all: hello

hello: main.o function1.o function2.o
		$(CC) main.o function1.o function2.o -o hello

main.o: main.cpp
		$(CC) $(CFLAGS) main.cpp

function1.o: function1.cpp
		$(CC) $(CFLAGS) function1.cpp

function2.o: function2.cpp
		$(CC) $(CFLAGS) function2.cpp

clean:
		rm -rf *o hello

範例程式放在GitHub

Reference

鼓勵持續創作,支持化讚為賞!透過下方的 Like 拍手👏,讓創作者獲得額外收入~
版主10在2020年首次開設YouTube頻道,嘗試拍攝程式教學。想要了解更多的朋友歡迎關注我的頻道,您的訂閱就是最大的支持~如果想學其他什麼內容也歡迎許願XD
https://www.youtube.com/channel/UCSNPCGvMYEV-yIXAVt3FA5A

Search

    Table of Contents