您的位置:首页 > 运维架构 > Linux

Linux内核---7.Makefile学习笔记

2016-07-02 14:34 579 查看
Makefile 学习笔记--记录用来忘记的东东

Makefile总是一边学一边忘,好记性不如烂笔头,这次把遇到的东东全都写下来,下次再用到的时候直接查就是了。

1. Makefile  $@, $^, $<  这三个自动化变量老是忘,先记下来

    $@        表示目标文件

    $^        表示所有的依赖文件

    $<        表示第一个依赖文件

    $?        表示比目标还要新的依赖文件列表

2. Makefile 中添加调试信息

    执行到error时会中断,warning不中断makefile的执行, info不打印当前makefile名和行号。 用法:$(warning "some text")

3. -include 与include的区别

   include rules.mk 当rules.mk不存在时,"Makefile:1: rules.mk: No such file or directory", 当使用-include时,继续执行不会报错而停止。

   补充:- 在每一个命令前加上-, 会忽略出错,不打断执行流程。最典型的例子是:

   -rm 1.o 2.o 3.o, 当1.o找不到时不会中止Makefile的执行流程,继续往下执行。        

4. @echo 与 echo的区别

   在要执行语句前加@不会打印该语句,如:echo "some text"和 @echo "some text"分别会打印:echo "some text"  some text 和 some text

5. ifeq判断字符串为空

   类似于 ifeq ($(VAL),)  当VAL为空时条件成立

6. filter 与 filter-out

   objects=main1.o foo.o bar.o main2.o      mains=main1.o main2.o

   $(filter-out $(mains), $(objects)) 值为 foo.o bar.o

   $(filter-out $(mains), $(objects)) 值为 main1.o main2.o

7. FORCE每次都更新目标,测试Makefile如下

   all: hello

   hello: hello.c

       gcc -g -o hello hello.c

   FORCE:

   .PHONY: FORCE

每次make时都会重新生成一次hello. 否则会打印make: Nothing to be done for `all'
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: