MAKEFILE

1、总体规则

target ... : prerequisites ...

   command

   ...

定义好依赖关系后,后续的那一行定义了如何生成目标文件的操作系统命令。

2、可以定义变量

只要make看到一个[.o]文件,它就会自动的把[.c]文件加在依赖关系中

objects = main.o kbd.o command.o display.o /

              insert.o search.o files.o utils.o

使用$(object)来替代这些.O文件

3、MAKEFILE自动推导功能

 

main.o : defs.h等价于main.o : defs.h main.c

4、清空目标文件

 

clean :

                -rm edit $(objects)

小横线表示出错了也不用管;

5、注意

Makefile中的命令,必须要以[Tab]键开始。

6、引用其它MAKEFILE

include <filename>

7、在规则中使用通配符

“~/test”,这就表示当前用户的$HOME目录下的test目录。

“*”“?”“[...]”

8、文件搜寻

 VPATH = src:../headers“src”“../headers”make会按照这个顺序进行搜索。目录由冒号分隔。

9、一个例子:

    objects = foo.o bar.o

     all: $(objects)

     $(objects): %.o: %.c

            $(CC) -c $(CFLAGS) $< -o $@

 上面的例子中,指明了我们的目标从$object中获取,“%.o”表明要所有以“.o”结尾的目标,也就是“foo.o bar.o”,也就是变量$object集合的模式,而依赖模式“%.c”则取模式“%.o”“%”,也就是“foo bar”,并为其加下“.c”的后缀,于是,我们的依赖目标就是“foo.c bar.c”。而命令中的“$<”“$@”则是自动化变量,“$<”表示所有的依赖目标集(也就是“foo.c bar.c”),“$@”表示目标集(也就是oo.o bar.o”)。

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值