C++关于Makefile的详解含通用模板

时间:2021-05-20

介绍

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 helloworldmain.o: main.cpp test.h g++ -c main.cpp -o main.otest.o: test.cpp test.h g++ -c test.cpp -o test.oclean: 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 = helloworldGCC = 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 = helloworldGCC = g++SUBDIR = src libCPP_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++项目,欢迎收藏

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对的支持。如果你想了解更多相关内容请查看下面相关链接

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章