概述
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)- @^$符号的意义所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复