C++中Makefile的作用是什么,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
网站建设哪家好,找创新互联公司!专注于网页设计、网站建设、微信开发、成都微信小程序、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了开平免费建站欢迎大家使用!
介绍
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 helloworld main.o: main.cpp test.h g++ -c main.cpp -o main.o test.o: test.cpp test.h g++ -c test.cpp -o test.o clean: 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 = helloworld GCC = 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 = helloworld GCC = g++ SUBDIR = src lib CPP_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)
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。
分享标题:C++中Makefile的作用是什么
标题来源:http://scpingwu.com/article/igioii.html