makefile笔记

1、var=`pwd`            var=$(shell pwd)
    all:
echo $(var)

    都可执行shell命令

2、Makefile中make版export

    同上,小标题的意思是,这里的export完全是make语法中的操作符。它通常是用来向后来发起的make进程

    (这些后起的make进程由当前的make进程启动)传送变量。

3、ifdef O
    ifeq ("$(origin O)", "command line")
    BUILD_DIR := $(O)
    endif
    endif
    all:

echo $(BUILD_DIR)

    如果在命令行输入了O=123,运行就会输出123。origin函数判断是都变量被定义。

4、.PHONY:clean

    clean:

        -rm a.o b.o

    rm之前-忽略执行过程中的错误

    用伪目标.PHONY防止本文件有名为clean的文件,必须是PHONY

    如果本路径有clean这个文件,执行makeclean会显示clean已经是最新

5、echo $(CURDIR)显示当前的路径,但是CURDIR在shell中没定义。

6、objects = *.o。它表示变量objects的值是字符串*.o(并不是期
    望的空格分开的.o 文件列表)。当需要变量objects代表所有.o 文件列表示,需要使

    用函数wildcardobjects = $(wildcar*.o))。在规则中,通配符会被自动展开。但在变量的定义和函数引用时,    通配     符将失效

7、~john/bin就是代表用户john 的宿主目录下的bin 目录。

8、LIBS= libtest.a
    foo : foo.c | $(LIBS)

    $(CC) $(CFLAGS) $< -o $@ $(LIBS)
    make在执行这个规则时,如果目标文件“ foo”已经存在。当“ foo.c”被修改以后,目标“ foo”

    将会被重建,但是当“ libtest.a”被修改以后。将不执行规则的命令来重建目标“ foo”。

9、$@--目标文件,$^--所有的依赖文件,$<--第一个依赖文件。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值