makefile-设计规则

1. makefile相关符号

:	 依赖开始
<Tab>命令开始  
#	 注释符号  
\	 续行号  
%	 任意一个
*	 所有  
?	 匹配  
[…]	 通配符
默认文件名GNUmakefile、makefile、Makefile

1.定义变量

定义	VARNAME=string  
使用	${VARNAME}  

Shell的变量用${},不能使用$()访问变量
严格说Makfile的变量用$(),但是Makefile的执行离不开shell环境,
因此使用${}也可以访问,是因为解析的时候使用shell解析.

2.隐含规则

.PHONY	伪目标
$@	代表目标文件  
$^	代表依赖文件
$<	第一个依赖文件的名称 
$+	所有的依赖文件,以空格分开,并以出现的先后为序,可能包含重复的依赖文件  
$?	所有时间戳比目标文件晚的依赖文件,并以空格分开  

$*	不包含扩展名的目标文件名称  

3.函数

$(函数名 参数1  参数2 参数3 参数4)

示例

1.最初版的makefile:
test:prog.o code.o
	gcc –o test prog.o code.o
prog.o:prog.c prog.h code.h
	gcc –c prog.c –o prog.o
code.o:code.c code.h
	gcc –c code.c –o code.o
clean:
	rm –f *.o  

2.加了变量后的makefile:
OBJS=prog.o code.o
CC=gcc  
test:${ OBJS }
	${ CC } –o test ${ OBJS }
prog.o:prog.c prog.h code.h
	${ CC } –c prog.c –o prog.o
code.o:code.c code.h
	${ CC } –c code.c –o code.o
clean:
	rm –f *.o  

3.使用隐含规则后的makefile:
OBJS=prog.o code.o
CC=gcc
test:${ OBJS }
	${ CC } –o $@ $^
prog.o:prog.c prog.h code.h
code.o:code.c code.h
clean:
	rm –f *.o 
编译链接过程
shell命令格式:
.c-->.i-->.s--->.o---elf 
.h

预编译:gcc -E hello.c -o hello.i
汇编:gcc -S hello.i -o hello.s
编译:gcc -c hello.s -o hello.o
链接:gcc hello.o -o hello

makefile格式:
目标文件:依赖文件
	命令	
hello:hello.o
	gcc hello.o -o hello
hello.i:hello.c
	gcc -E hello.c -o hello.i 
hello.s:hello.i
	gcc -S hello.i -o hello.s
hello.o:hello.s
	gcc -c hello.s -o hello.o
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值