linux Makefile常用语法持续记录

本文深入探讨了Makefile中的高级语法,包括参数赋值、特殊变量、通配符扩展、循环语句、过滤操作及伪目标的使用。通过具体实例,讲解了如何利用这些特性进行高效的构建管理和依赖处理。

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

=、:=、?=、+=

参数赋值

= 是最基本的赋值
:= 是覆盖之前的值
?= 是如果没有被赋值过就赋予等号后面的值
+= 是添加等号后面的值


$@ 、$^、$< 、$? 

$@  表示目标文件
$^  表示所有的依赖文件
$<  表示第一个依赖文件
$?  表示比目标还要新的依赖文件列表


@、-、+

@:使命令被执行前不回显

-:使任何命令行的任何非零退出状态都被忽略,忽略错误

+:使命令行可以通过指定 -n、-q 或 -t 选项来执行


wildcard、patsubst 、foreach、nodir

wildcard 扩展通配符

$(wildcard PATTERN...)

例如:$(wildcard *.c)  获取本目录下所有的.c文件列表,这个一般和patsubst配合使用

 

patsubst 替换通配符

OBJ = $(patsubst %.c %.o $(wildcard  *.c))

首先使用wildcard获取当前目录所有.c文件列表,然后使用patsubst将所有后缀.c替换为.o

 

foreach 循环语句

$(foreach <var>,<list>,<text>)

<list>列表中逐一取出参数放到<var>中,然后执行<text>包含的表达式

例如:names := a b c d

           files := $(foreach n,$(names),$(n).o) //name中挨个取出放到n中,执行$(n).o,所以files返回值为:a.o b.o c.o d.o

 

nodir 去除路径名,只保留文件名

src := $(wildcard arch/arm/configs/*.c

$(nodir $(src))  为1.c 2.c


find

查询匹配

srcs := $(shell find $(src_dir) -name *.c -o -name *.cpp)

找到所有src_dir目录下的.c或者.cpp文件,保存在srcs中

-o 是或者的意思  

-a 是而且的意思  

-not 是相反的意思


filter / filter-out

过滤、反过滤

$(filter PATTERN…,TEXT) 

过滤掉字串“TEXT”中所有不符合模式“PATTERN”的单词

srcs = a1.c a2.c b1.h b2.c

srcs = $(filter %.c, $(srcs))

返回值a1.c a2.c

$(filter-out PATTERN...,TEXT) 

过滤掉字串“TEXT”中所有符合模式“PATTERN”的单词

srcs = a1.c a2.c b1.h b2.h

srcs = $(filter-out %.c, $(srcs))

返回值为b1.h b2.h


.PHONY

伪目标,防止Makefile中执行目标和时间文件名发生冲突

clean:

        rm -f*.o

如果本目录存在clean文件,make clean会冲突报错

修改如下:

.PHONY clean

clean:

        rm -f *.o


addprefix / addsuffix

addprefix :为每一项NAME添加前缀PREFIX

$(addprefix src/,foo bar)

返回为:src/foo src/bar

addsuffix:为每一项NAME添加后缀PREFIX

$(addprefix  .o,foo bar)

返回为:foo.o bar.o

详细易懂的Linux makefile教程 一、概述 什么是makefile?或许很多Winodws的程序员都不知道这个东西,因为那些Windows的IDE都为你做了这个工作,但我觉得要作一个好的和professional的程序员,makefile还是要懂。这就好像现在有这么多的HTML的编辑器,但如果你想成为一个专业人士,你还是要了解HTML的标识的含义。特别在Unix下的软件编译,你就不能不自己写makefile了,会不会写makefile,从一个侧面说明了一个人是否具备完成大型工程的能力。 因为,makefile关系到了整个工程的编译规则。一个工程中的源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为makefile就像一个Shell脚本一样,其中也可以执行操作系统的命令。 makefile带来的好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大的提高了软件开发的效率。make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说,大多数的IDE都有这个命令,比如:Delphi的make,Visual C++的nmake,Linux下GNU的make。可见,makefile都成为了一种在工程方面的编译方法。 现在讲述如何写makefile的文章比较少,这是我想写这篇文章的原因。当然,不同产商的make各不相同,也有不同的语法,但其本质都是在“文件依赖性”上做文章,这里,我仅对GNU的make进行讲述,我的环境是RedHat Linux 8.0,make的版本是3.80。必竟,这个make是应用最为广泛的,也是用得最多的。而且其还是最遵循于IEEE 1003.2-1992 标准的(POSIX.2)。 在这篇文档中,将以C/C++的源码作为我们基础,所以必然涉及一些关于C/C++的编译的知识,相关于这方面的内容,还请各位查看相关的编译器的文档。这里所默认的编译器是UNIX下的GCC和CC。 二、关于程序的编译和链接 —————————— 在此,我想多说关于程序编译的一些规范和方法,一般来说,无论是C、C++、还是pas,首先要把源文件编译成中间代码文件,在Windows下也就是 .obj 文件,UNIX下是 .o 文件,即 Object File,这个动作叫做编译(compile)。然后再把大量的Object File合成执行文件,这个动作叫作链接(link)。 ...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值