makefile书写规则-创新互联

1 makefile 基本规则

TARGET … : DEPENDENCIES …
  COMMAND
  …
·目标(TARGET)程序产生的文件,如可执行文件和目标文件;目标也可以是要执行的动作,如“clean”。
·依赖(DEPENDENCIES)是用来产生目标的输入文件,一个目标通常依赖于多个文件。
·命令(COMMAND)是make执行的动作,一个可以有多个命令,每个占一行。注意:每个命令行的起始字符必须为TAB字符
·如果DEPENDENCIES中有一个或多个文件更新的话,COMMAND就要执行,这就是Makefile最核心的内容。

创新互联专注骨干网络服务器租用10年,服务更有保障!服务器租用,成都服务器托管 成都服务器租用,成都服务器托管,骨干网络带宽,享受低延迟,高速访问。灵活、实现低成本的共享或公网数据中心高速带宽的专属高性能服务器。

1.1 makefile使用伪目标.PHONY

makefile书写规则

makefile书写规则

1.2 makefile使用变量

makefile书写规则

1.2.1 makefile自动化变量

makefile书写规则
makefile书写规则

2 make自动推导

·GNU的make很强大,它可以自动推导文件以及文件依赖关系后面的命令,于是我们就没必要去在每一个[.o]文件后都写上类似的命令,因为,我们的make会自动识别,并自己推导命令。

·只要make看到一个[.o]文件,它就会自动的把[.c]文件加在依赖关系中,如果make找到一个whatever.o,那么 whatever.c,就会是whatever.o的依赖文件。并且 gcc -c whatever.c 也会被推导出来。
makefile书写规则
makefile书写规则

3 makefile通用版

3.1 makefile中常见函数

--wildcard函数
  当前目录下匹配模式的文件 例如:src=$(wildcard .c)
--notdir函数
  去除路径 例如:$(notdir $src)
--patsubst函数
  模式匹配替换 例如:$(patsubst%.c,%.o,$src)
  等价于$(src:.c=.o)
--shell函数
  执行shell命令 例如:$(shell ls –d
/)
makefile书写规则

3.2 多级目录makefile

makefile书写规则
makefile书写规则

  这里有一个要注意的地方,用g++编译C++文件的话,用到的库必须是由g++编译生成的,否则链接不了。
  关于g++和gcc,虽然说g++是用来编译.cpp,gcc是用来编译.c的,但是也不能说二者完全没有交叉。
  事实上,两者都可以编译C和C++代码,但是:、
  1)gcc把.c文件当做是C程序,而g++当做是C++程序;而对于.cpp文件,二者都会认为是C++程序
  2)所以说,在编译阶段,g++会调用gcc,对于C++代码,二者是等价的,但是因为gcc命令不能自动和g++编译的库链接,所以,通常用g++来完成链接。
 因此,为了方便起见,都用g++来编译我们的库文件。
  最后附上一个我看到的文章http://m.blog.csdn.net/zhujianwei31415/article/details/50725569
,gcc与g++编译链接库文件的兼容性问题,有利于理解。

另外有需要云服务器可以了解下创新互联cdcxhl.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。


当前名称:makefile书写规则-创新互联
链接URL:http://myzitong.com/article/gioii.html