makefile 简介

1.简单的命令格式
target : prerequisites
recipe

target 通常是一个程序生出的文件名,比如对象文件(.o),也可能是一个将要执行的动作命令 比如 clean
prerequisites 通常是一个或多个生成 target 所需要的文件
recipe 是 make 要执行的方法,可以一个或多个,可以使一行或多行,注意每行都需要 tab 缩进,.RECIPEPREFIX变量可以修改 tab 为其他字符

在一条命令中,recipe 和 prerequisites 都是为如何生成 target 服务的
但是,执行 recipe 不一定要有 prerequisites,比如 clean
有一些 target ,不是file,不作为任何 rules 的 prerequisites,称为 空头target (phony target),执行时,必须显示指明 target ,如 make clean
e.g.
edit : main.o kbd.o command.o display.o insert.o search.o files.o utils.o
	cc -o edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o
main.o : main.c defs.h
	cc -c main.c
kbd.o : kbd.c defs.h command.h
	cc -c kbd.c
command.o : command.c defs.h command.h
	cc -c command.c
display.o : display.c defs.h buffer.h
	cc -c display.c
insert.o : insert.c defs.h buffer.h
	cc -c insert.c
search.o : search.c defs.h buffer.h
	cc -c search.c
files.o : files.c defs.h buffer.h command.h
	cc -c files.c
utils.o : utils.c defs.h
	cc -c utils.c
clean :
	rm edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o
2.make 处理 makefile 
默认 make 首先处理第一个不以.开头的 target ,在执行其 recipe 前,先检查 prerequisites 和他们各自的 prerequisites。 只要 prerequisites 比 target 新或者 target 不存在,其 recipe 就会执行
上面例子中,首先处理的 target 是 edit,检查 prerequisites 中所有 .o 文件以及对应的 prerequisites.
比如改变了 command.h,则重新编译kbd.o, command.o, files.o 三个文件,最后重新链接所有 .o 文件

3.使用变量
上列中重复使用了 3个文件列表,如果我们添加或删除了某个 target 或 prerequisites,不得不同时修改3处,容易发生遗漏
这时可以使用变量简化程序
objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o
edit : $(objects)
	cc -o edit $(objects)
...
clean :
	rm edit $(objects)

4.使用隐式规则推断 recipe
我们总是用 cc -c xx.c xx.h -o xx.o 命令编译 .o 文件,这在 make 中是一条隐式规则,我们可以省略 prerequisites 中的与 .o 文件对应的 .c 文件以及 recipe
上面的列子简化为

objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o
edit : $(objects)
	cc -o edit $(objects)
main.o : defs.h
kbd.o : defs.h command.h
command.o : defs.h command.h
display.o : defs.h buffer.h
insert.o : defs.h buffer.h
search.o : defs.h buffer.h
files.o : defs.h buffer.h command.h
utils.o : defs.h

.PHONY : clean
clean :
	rm edit $(objects)<span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);">	</span>
5.如果 makefile 只使用了隐式规则,我们还可以通过分组入口(group entries)编写
objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o
edit : $(objects)
	cc -o edit $(objects)
$(objects) : defs.h
kbd.o command.o files.o : command.h
insert.o display.o files.o search.o : buffer.h
6.除了编译文件,makefile 还可以用来删除文件和可执行文件清理目录
.PHONY : clean
clean :
rm edit $(objects)

.PHONY : clean 避免 target clean 和 名为 clean 的文件混淆,clean 不应该放在 makefile的开始位置,否则他会成为默认 target, 而且它不是任何 target 的 prerequisites ,只能通过 make clean 执行

参考:《GNU make manual》2.An Introduction to Makefiles

手册下载地址:http://www.gnu.org/software/make/manual/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值