答案:一个简单的C++ Makefile通过定义编译器、源文件、目标文件和规则,实现自动化编译;包含all、clean、rebuild目标,支持编译、清理与重新构建。

编写一个简单的 C++ 项目 Makefile,核心是定义编译规则,告诉 make 如何生成目标文件和可执行程序。下面是一个基础但实用的 Makefile 写法,适合初学者快速上手。
1. 基本结构:定义变量与规则
Makefile 使用变量来简化重复内容,比如编译器、编译选项、源文件列表等。
CC = g++
CFLAGS = -Wall -g
立即学习“C++免费学习笔记(深入)”;
SOURCES = main.cpp util.cpp
OBJECTS = $(SOURCES:.cpp=.o)
EXECUTABLE = myapp
说明:
- CC:指定使用的编译器,这里用 g++。
- CFLAGS:编译选项,-Wall 显示所有警告,-g 添加调试信息。
- SOURCES:列出所有源文件。
- OBJECTS:利用字符串替换,将 .cpp 转为 .o,生成目标文件列表。
- EXECUTABLE:最终生成的可执行文件名。
2. 编写构建规则
Makefile 的核心是规则:目标 : 依赖,后跟命令。
all: $(EXECUTABLE)
$(EXECUTABLE): $(OBJECTS)
$(CC) $(OBJECTS) -o $(EXECUTABLE)
.cpp.o:
$(CC) $(CFLAGS) -c $
说明:
- all 是默认目标,运行 make 时执行它。
- $(EXECUTABLE): $(OBJECTS) 表示可执行文件依赖于所有 .o 文件。
- .cpp.o 是隐式规则,告诉 make 如何把 .cpp 编译成 .o。
- $ 代表第一个依赖(源文件),$@ 代表目标文件。
3. 添加清理和重新构建目标
方便开发过程中清除生成文件。
clean:
rm -f $(OBJECTS) $(EXECUTABLE)
rebuild: clean all
运行 make clean 删除编译产物,make rebuild 重新完整构建。
4. 使用示例
假设你有 main.cpp 和 util.cpp 两个文件,放在同一目录下,创建名为 Makefile 的文件(注意大小写),内容如下:
CC = g++
CFLAGS = -Wall -g
SOURCES = main.cpp util.cpp
OBJECTS = $(SOURCES:.cpp=.o)
EXECUTABLE = myapp
all: $(EXECUTABLE)
$(EXECUTABLE): $(OBJECTS)
$(CC) $(OBJECTS) -o $(EXECUTABLE)
.cpp.o:
$(CC) $(CFLAGS) -c $
clean:
rm -f $(OBJECTS) $(EXECUTABLE)
rebuild: clean all
在终端执行:
- make —— 编译生成 myapp
- make clean —— 清理
- make rebuild —— 重新构建
基本上就这些。一个简单的 C++ Makefile 就是定义好源文件、编译器、规则和清理动作。随着项目变大,可以引入头文件依赖自动检测或分目录管理,但这个基础版本已经足够开始使用。










