Chinaunix首页 | 论坛 | 博客
  • 博客访问: 58310
  • 博文数量: 20
  • 博客积分: 10
  • 博客等级: 民兵
  • 技术积分: 50
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-02 09:49
文章分类
文章存档

2014年(2)

2013年(11)

2012年(5)

2011年(2)

我的朋友

分类: LINUX

2013-05-05 17:07:56

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'


阅读(1109) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~