Makefile:基本规则

【变量】=【值】#普通赋值

【变量】:=【值】#覆盖之前的值

【变量】?=【值】#如果没有赋值过,则赋值等号后的值

【变量】+=【值】#添加等号后面的值

【目标文件】:【依赖文件】#递归性质,最终目标为第一行的目标文件

        【命令】#命令前有一个tab

【目标文件1】:【依赖文件1】#目标文件1一般包含在第一行依赖文件里

        【命令1】

【目标文件2】:【依赖文件2】#目标文件2一般包含在第一行依赖文件里

        【命令2】

【clean】

        【删除命令】

【install】

        【安装命令】

【uninstall】

        【卸载命令】

例:

FILE = main.o func1.o func2.o

hello: $(FILE) #等同于 hello: main.o func1.o func2.o
    gcc $(FILE) -O hello

main.o: main.c
    gcc -c main.c

func1.o: func1.c
    gcc -c func1.c

func2.o: func2.c
    gcc -c func2.c

clean:
    rm $(FILE) hello

install:
    cp hello /usr/local/hello

uninstall:
    rm hello /usr/local/hello

变量赋值"="与":="的区别

1、“=”

      make会将整个makefile展开后,再决定变量的值。也就是说,变量的值将会是整个makefile中最后被指定的值。看例子:

            x = foo
            y = $(x) bar
            x = xyz

      在上例中,y的值将会是 xyz bar ,而不是 foo bar 。

      2、“:=”

      “:=”表示变量的值决定于它在makefile中的位置,而不是整个makefile展开后的最终值。看例子

            x := foo
            y := $(x) bar
            x := xyz

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值