概述
简单的记录了一下,在使用makefile中遇到的一些问题。在之前记录一下 鸟哥书中的描述的make一些优点:
- 简化编译时所需要执行的命令
- 若在编译完成之时,修改了某个源代码文件,则make仅会针对被修改的文件进行编译,其他的目标文件不会进行编译
- 最后可以根据依赖性来更新我执行文件。
基本规则
1)基本的一些结构
target ... : prerequisites ...
【tab】 command
【tab】 command
2)【tab】处于命令行的第一个字符, 目标与相关文件之间要是用‘:’进行间隔
3)可以在文件中设置环境变量,简化makefile的编写
OBJS = main.o user.o
$(OBJS) 代表了等号后面的语句等价
4)常用语法举例:
#环境变量设置
OBJ = main.o user.o
#编译部分
edit:$(OBJ)
[tab]gcc -Wall -o edit(生成文件名) $(OBJ)
#make clean 部分
.PHONY:clean
clean:
[tab]rm edit(生成的可执行文件) $(OBJ)
其中-Wall表示显示出所有的编译警告信息
基本的语法知识
常见问题
1)多级目录下编译文件。
在代码的文件夹下面存在 include、src文件夹 include中存放着头文件,src中存放着用户的文件
在此时如果使用上面的makefile会出现无法找到文件的错误,查阅相关的文档以后,找到了一个处理方法
使用 vpath 变量对于不同的文件进行不同的搜索处理方式,例如:
#后缀为.c的文件搜索目录 src
vpath %.c src
使用上述的语句以后能够将 src、include目录中的文件识别出来,正常编译。
a). 对于vpath这个变量在文档中还有另外的一个相对的变量gpath,在目前没有看出具体的应用区别,mark一下,留待查询。
中文版_Makefile的规则 (gpath具体见章节4.5.3 目录搜索的机制)
附录:
2