您的位置:首页 > 其它

MAKEFILE 学习笔记 —— 实用功能

2016-03-03 18:18 281 查看

MAKEFILE 学习笔记 —— 实用功能

一. 变量的使用

当我们的程序越来越复杂时,变量的使用可以大大提高我们的效率。makefile 中变量的使用有点类似于 c 语言中的宏,格式如下
name = file
使用变量时应该加上$(),代码如下所示


obj = main.o func.o
aaa:    $(obj)
gcc -o aaa  main.o  func.o
main.o: main.c  ex2.h
gcc -std=c99 -c main.c
func.o: func.c  ex2.h
gcc -std=c99 -c func.c

clean:
rm -fr $(obj) aaa


name:变量的名字,如以上代码中的 obj

file :变量所代表的文件名 如以上代码中的 main.o func.o

二. make的自动推导

在我们使用make进行编译链接时,像以上示例的代码不免有些麻烦,而 make 有一个自动推导的功能可以大大提高工作效率。即,当 make 发现一个 .o 文件时,便会自动将其所依赖的 .c 文件加载进来,这被称为自动推导,这也被称为 make 的隐晦规则。如下示例便是上面那个例子的 make 自动推导版。


obj = main.o func.o
aaa:    $(obj)
gcc -o aaa  main.o  func.o
main.o:     ex2.h
func.o:     ex2.h

clean:
rm -fr $(obj) aaa


三. 共用.h文件

当我们的许多 .c 文件共用一个 .h 文件时,每次都写入同一个 .h 文件未免太麻烦,这里有一个精简的方法,即共用 .h 文件,如下代码:


obj = main.o func.o
aaa:    $(obj)
gcc -o aaa  main.o  func.o
main.o func.o:      ex2.h

clean:
rm -fr $(obj) aaa


如以上代码,将共用同一个 .h 文件的目标文件写在同一行内即可。


四. 打扫

当我们编译完程序之后,便要清理一下所生成的那些链接文件。如下代码


obj = main.o func.o
aaa:    $(obj)
gcc -o aaa  main.o  func.o
main.o func.o:      ex2.h

.PHONY: clean
clean :
-rm -fr $(obj) aaa


PHONY: clean 是声明 clean 是伪目标

rm 之前的 “-” 是告诉 make 若编译时遇到错误,不用管,继续向下编译。

参考文献

[1] 陈浩《跟我一起写Makefile》
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  makefile 变量 clean make