2021/02/24 MakeFile 基本使用

MakeFile 文件中的规则

target(目标)…:prerequisites(先决条件)…
[tab] command(命令)
……


例如:
``
edit : main.o kbd.o command.o display.o insert.o search.o files.o utils.o

[tab] 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
[tab] cc -c main.c
kbd.o : kbd.c defs.h command.h
[tab] cc -c kbd.c
command.o : command.c defs.h command.h
[tab] cc -c command.c
display.o : display.c defs.h buffer.h
[tab] cc -c display.c
insert.o : insert.c defs.h buffer.h
[tab] cc -c insert.c
search.o : search.c defs.h buffer.h
[tab] cc -c search.c
files.o : files.c defs.h buffer.h command.h
[tab] cc -c files.c
utils.o : utils.c defs.h
[tab] cc -c utils.c

clean :
rm edit main.o kbd.o command.o display.o insert.o search.o files.o utils.o
``

MakeFile 变量

OBJECTS = main.o kbd.o command.o display.o insert.o search.o files.o utils.o


简化为:
objects = main.o kbd.o command.o display.o insert.o search.o files.o utils.o

edit : $(objects)
[tab] 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

clean :
[tab] -rm edit $(objects)

隐含规则中的自动变量

自动变量’¥^'的值表示规则的所有先决条件,包括它们所处目录的名称;
'¥<'的值表示规则中的第一个先决条件;'¥@'表示目标对象(另外还有一些自动变量的含义请参考 make
手册)。有时,当我们不想在命令行中指定头文件时,可以在先决条件中包含这些头文件。此时自动变量
'¥<'正是第一个先决条件。


foo.o : foo.c defs.h hack.h
cc -c $(CFLAGS) $< -o $@


其中的’¥<’就会被自动地替换成 foo.c,而¥@则会被替换为 foo.o。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值