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

本文介绍了Makefile中的实用技巧,包括自动化变量$@、$^、$<的应用,如何添加调试信息,-include与include的区别,@echo与echo的区别,ifeq判断字符串为空,filter与filter-out的使用,以及FORCE目标的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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'

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值