02-makefile隐含规则
2016-12-03 13:04
435 查看
1.编译C程序的隐含规则。
<n>.o的目标的依赖目标会自动推导为
<n>.c,并且其生成命令:
$(CC) –c $(CPPFLAGS) $(CFLAGS)
2.链接Object文件的隐含规则。
<n>目标依赖于
<n>.o,通过运行C的编译器来运行链接程序生成(一般是“ld”),其生成命令是:
$(CC) $(LDFLAGS) <n>.o $(LOADLIBES) $(LDLIBS)。
2.1可以自己写ld链接规则(-T)
$(CC) $(LDFLAGS) -T myld.ld $(SRC) vector.o -o main
其中
myld.ld关于内存的一些信息。
3.隐含规则使用的变量
make的-R或
--no– builtin-variables参数来取消你所定义的变量对隐含规则的作用。1.关于命令的变量。
-
AR函数库打包程序。默认命令是“ar”。
-
RM删除文件命令。默认命令是“rm –f”。
- 2.关于命令参数的变量
-
ARFLAGS函数库打包程序AR命令的参数。默认值是“rv”。
-
CFLAGSC语言编译器参数
4.隐含规则链
5.定义模式规则
%的意思是表示一个或多个任意字符。在依赖目标中同样可以使用
%,只是依赖目标中的
%的取值,取决于其目标。
1、模式规则介绍
%.o : %.c ; <command ......>
2、模式规则示例
$(CC) -c $(CFLAGS) $(CPPFLAGS) $< -o $@
3、自动化变量
-
$@就是匹配于目标中模式定义的集合。
-
$%仅当目标是函数库文件中,表示规则中的目标成员名。
-
$<依赖目标中的第一个目标名字。如果依赖目标是以模式(即
%)定义的,那么
$<将是符合模式的一系列的文件集。注意,其是一个一个取出来的。
-
$?所有比目标新的依赖目标的集合。以空格分隔。
-
$^所有的依赖目标的集合。以空格分隔。如果在依赖目标中有多个重复的,那个这个变量会去除重复的依赖目标,只保留一份。
-
$+这个变量很像
$^,也是所有依赖目标的集合。只是它不去除重复的依赖目标。
-
$*这个变量表示目标模式中
%及其之前的部分。
相关文章推荐
- “Makefile:xxx:***混合的隐含和普通规则。停止”
- Makefile十五隐含规则的变量
- makefile 隐含规则
- makefile--隐含规则
- Makefile‘混和的隐含和普通规则’错误的解决
- Linux makefile教程之隐含规则九[转]
- C语言的本质(37)——makefile之隐含规则和模式规则
- makefile高级用法--隐含规则
- Makefile (八)之 隐含规则
- Makefile详解--隐含规则
- Makefile隐含规则和用到的默认变量
- Makefile十七之后缀规则和隐含规则的搜索算法
- Makefile完全解析PART9.隐含规则
- Makefile 隐含规则
- Makefile (十) 隐含规则
- 隐含规则-Makefile
- C语言的本质(37)——makefile之隐含规则和模式规则
- 跟我一起写makefile-9(隐含规则)
- Makefile中使用隐含规则来编译程序
- Makefile之隐含规则