c++多文件编译makefile的编写
时间: 2023-09-21 11:11:42 浏览: 130
多文件编译是指将一个大的程序分成多个小的模块,每个模块独立完成一部分功能,然后再将它们合并起来。在 C++ 中,每个模块通常对应一个 .cpp 文件,其中包含了该模块的实现代码,以及一个 .h 文件,其中包含了该模块的声明和定义。
makefile 是一种用来自动化编译程序的工具,可以根据源代码的依赖关系,自动地编译出可执行程序。下面是一个简单的 makefile 示例,假设我们有两个源代码文件 main.cpp 和 func.cpp,分别对应主函数和某个函数的实现。
```makefile
CC = g++
CFLAGS = -Wall -g
OBJS = main.o func.o
all: program
program: $(OBJS)
$(CC) $(CFLAGS) -o program $(OBJS)
main.o: main.cpp func.h
$(CC) $(CFLAGS) -c main.cpp
func.o: func.cpp func.h
$(CC) $(CFLAGS) -c func.cpp
clean:
rm -f program *.o
```
上面的 makefile 分为三个部分:
- 变量定义:定义了编译器和编译选项,以及目标文件的名字。
- 目标声明:声明了要生成的目标文件 program,以及它依赖的源代码文件。
- 规则定义:定义了每个源代码文件的编译规则,以及如何生成目标文件。
其中,变量定义部分可以根据实际情况进行修改。目标声明部分需要根据实际的源代码文件进行修改。规则定义部分则是最关键的部分,它定义了如何将源代码文件编译成目标文件,以及如何将多个目标文件链接成可执行程序。
在上面的示例中,我们使用了变量 $(CC) 和 $(CFLAGS),它们分别表示编译器和编译选项。变量 $(OBJS) 则表示所有的目标文件,即 main.o 和 func.o。目标声明部分定义了一个名为 program 的目标文件,它依赖于 main.o 和 func.o 两个源代码文件。规则定义部分则使用了两个模式规则,分别定义了如何将 main.cpp 和 func.cpp 编译成目标文件。
最后,在命令行中执行 make 命令即可自动编译生成可执行程序。如果需要清除生成的文件,可以执行 make clean 命令。
阅读全文