makefile
Posted bewolf
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了makefile相关的知识,希望对你有一定的参考价值。
makefile 语法:
目标文件:生成目标文件的依赖文件
生成目标文件所需要执行的动作(必须以tab键开头)
常用变量代表的意思: [email protected]目标文件,$^--所有的依赖文件,$<--第一个依赖文件。
~--当前用户目录,*所有符号的通配符
常用的查找包含符号:-I 将目标作为第一个寻找头文件的目标
-L将目标作为第一个寻找库文件的目标
-l在目标中寻找.so文件,如-lword在指定目录寻找libworld.so这个动态库文件
make可以自动推导文件以及文件依赖关系后面的命令,于是我们就没必要去在每一个[.o]文件后都写上类似的命令,因为,我们的make会自动识别,并自己推导命令。只要make看到一个[.o]文件,它就会自动的把[.c]文件加在依赖关系中,如果make找到一个whatever.o,那么whatever.c,就会是whatever.o的依赖文件。并且 cc -c whatever.c 也会被推导出来。所以这样也是可行的 whatever.o : defs.h,当然这样会降低makefile的可读性。
伪目标:
为了避免和文件重名的这种情况,我们可以使用一个特殊的标记“.PHONY”来显示地指明一个目标是“伪目标”,向make说明,不管是否有这个文件,这个目标就是“伪目标”。
只要有这个声明,不管是否有“clean”文件,要运行“clean”这个目标,只有“make clean”这样。于是整个过程可以这样写:
.PHONY: clean
clean:
rm *.o temp
命令:
显示命令:echo 。。。
如果你要让上一条命令的结果应用在下一条命令时,你应该使用分号分隔这两条命令。
常用的在目标文件夹中包含所有的c文件命令:shell find 路径 -maxdepth -name "*.c"
判断目录是否存在命令:shell if [! -d ‘/data/‘] 如果data目录不存在,则执行。。。
编译宏以“define”开始,以“endef”结束
gcc常用参数:
-o指定输出文件名
-O优化编译、链接
-c只编译不链接
-g增加gdb调试
-w关闭编译告警
-W打开编译告警
-fPIC产生与位置无关的代码(生成动态库.SO时候用)
-WI,-Bsymbolic 强制动态库使用自己的符号
参考链接:https://blog.csdn.net/weixin_38391755/article/details/80380786
小型可参考的makefile模板:https://www.cnblogs.com/prettyshuang/p/5552328.html
以上是关于makefile的主要内容,如果未能解决你的问题,请参考以下文章
MakefileMakefile 中 LINUXINCLUDE 的作用
MakefileMakefile 中 LINUXINCLUDE 的作用