溫馨提示×

Linux中Makefile詳細教程

小云
99
2023-09-13 09:02:44
欄目: 智能運維

Makefile是一種用于構(gòu)建和管理軟件項目的工具,特別適用于C/C++項目。它可以通過定義一系列規(guī)則,指定文件的依賴關(guān)系和構(gòu)建命令來自動化編譯和構(gòu)建過程。下面是一個詳細的Makefile教程。

  1. 基本語法和規(guī)則

Makefile由一系列規(guī)則組成,每個規(guī)則包含一個目標(target)、依賴關(guān)系(prerequisites)和構(gòu)建命令(recipe)。

target: prerequisites
recipe
  • 目標(target)是要生成的文件或執(zhí)行的操作。

  • 依賴關(guān)系(prerequisites)是目標所依賴的文件或目標。

  • 構(gòu)建命令(recipe)是實際執(zhí)行的命令。

  1. 變量

Makefile中可以定義變量來存儲常用的命令、路徑等。

CC = gcc
CFLAGS = -Wall -g

變量可以在規(guī)則中使用:

$(CC) $(CFLAGS) -c foo.c -o foo.o
  1. 默認規(guī)則

如果Makefile沒有指定任何規(guī)則,默認規(guī)則會尋找名為"all"的目標,并嘗試構(gòu)建它。

all: target1 target2
  1. 偽目標

偽目標是一種特殊的目標,其不對應(yīng)任何實際的文件。它常用于定義執(zhí)行特定操作的規(guī)則。

.PHONY: clean
clean:
rm -f *.o

上述例子中,".PHONY"表示這是一個偽目標?!癱lean"規(guī)則的構(gòu)建命令會刪除所有”.o"文件。

  1. 模式規(guī)則

模式規(guī)則可以用來定義一類目標的構(gòu)建規(guī)則。其中,%表示通配符,匹配任意字符。

%.o: %.c
$(CC) $(CFLAGS) -c $< -o $@

上述例子中,“%.o: %.c"表示以.c為后綴的文件會被編譯成.o文件?!?<“表示第一個依賴文件,”$@"表示目標。

  1. 運行Makefile

要運行Makefile,可以使用make命令:

make

如果Makefile中有指定多個目標,可以通過指定目標名來構(gòu)建特定目標:

make target

以上是一個基本的Makefile教程,涵蓋了Makefile的基本語法和常用規(guī)則。通過合理使用Makefile,可以自動化編譯和構(gòu)建軟件項目,提高開發(fā)效率。

0