我是靠谱客的博主 痴情悟空,这篇文章主要介绍makefile学习笔记(1)- @^$符号的意义,现在分享给大家,希望可以做个参考。

makefile的基本用法如下,

target:components    ------<依赖语句>
TAB rule                        ------<规则语句>
这两行一般同时出现。

第一行表示的是依赖关系,
举例:某个.o目标文件依赖几个.c和.h,那么可以这么写:  main.o:main.c mytool1.h mytool2.h
又如:可执行文件依赖几个.c文件,那么可以这么写:test_exe: main.o comfunc.o
第二行表示规则(注意,规则前必须有一个tab键),所谓规则,就是怎么把依赖文件变成目标文件,也即,使用什么编译器,带哪些编译选项,
举例:把hello.o变成可执行文件,这么写:gcc -o hello hello.o,其中-o选项后面紧跟目标文件(目标文件可能是可执行文件、.o文件、汇编文件等)。

 

下面来看一下$@、 $^ 、%< 这三个符号,它们很常见,而且只会出现在”规则语句”中,其中:
$@代表目标文件,前文已经提到,<规则语句>前面一般会有一条<依赖语句>,依赖语句中已经指出了目标文件是谁;
$^代表所有的依赖文件;
$<代表第一个依赖文件。

下面利用这三个符号,来简化一下make语句:

原makefile文件:
main:main.o mytool1.o mytool2.o
gcc -o main main.o mytool1.o mytool2.o

简化后:
main:main.o mytool1.o mytool2.o
gcc -o $@ $^

 

最后

以上就是痴情悟空最近收集整理的关于makefile学习笔记(1)- @^$符号的意义的全部内容,更多相关makefile学习笔记(1)-内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(128)

评论列表共有 0 条评论

立即
投稿
返回
顶部