Makefile的基本规则实例说明



Makefile 规则:
目标:目标文件A 目标文件B ...
<tab> gcc -o 与监理的执行文件 目标文件1 目标文件2 ...
* Makefile 中的# 表示注释
* <tab> 要在命令行的第一个字符
* 目标文件和相关文件之间用“:”隔开
# 可以使用续行号(\)将单独一个命令延续成几行。但要注意在续行号后面不能跟任何字符


实例 1:
# 以#开头的为注释:
test: prog.o code.o #生成运行文件test需要用到prog.o 和code.o两个文件(如果make没有加生成的目标文件;则默认使用test)
gcc -o test prog.o code.o#生成test 的GCC命令
prog.o: prog.c prog.h code.h #生成目标文件prog.o需要用到prog.c prog.h 和code.h三个文件
gcc -c prog.c -o prog.o#生成prog.o的命令
code.o: code.c code.h#同prog.o的过程
gcc -c code.c -o code.o
clean:#Makefile的内部命令
rm -f *.o#清除所有以".o"结尾的文件


Makefile的更新从下向上按照时间戳,如果依赖文件的时间戳比生成文件的时间戳新则重新编译。


Makefile的变量就像是一个环境变量。事实上,环境变量在make中也被解释成make的变量。
Makefile的变量大小写敏感,并且基本上使用大写。
Makefile变量的主要作用:
a 保存文件名列表;
b 保存可执行命令名;
c 保存编译器的参数;
Makefile变量的写法:
VARNAME = string
Makefile变量的使用:
${VARNAME}


实例 2:
在实例 1使用变量代替部分文件:
OBJS = prog.o code.o
CC = gcc
test: ${OBJS}
${CC} -o test ${OBJS}
prog.o: prog.c prog.h code.h
${CC} -o prog.c -o prog.o
code.o: code.c code.h#同prog
${CC} -c code.c -o code.o
clean:
rm -f *.o


整理自makefile课件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值