UNIX编程--Makefile入门

Makefile 文件命名和规则

  • 文件命名
    • makefile 或者 Makefile
  • Makefile 规则
    • 一个 Makefile 文件中可以有一个或者多个规则
      目标 ... : 依赖 ...`
      	命令 (shell 命令)
      	...
      
      • 目标:最终要生成的文件,伪目标除外
      • 依赖:生成目标所需的文件或是目标
      • 命令:通过执行命令对依赖操作生成目标(命令前必须 Tab 缩进)

工作原理

  • 命令在执行前,需要先检查规则中的依赖是否存在
    • 如果存在,执行命令
    • 如果不存在,向下执行其他的规则,检查有没有一个规则是用来生成这个依赖的,如果找到了,则执行该规则的命令
  • 检测更新,在执行规则中的命令时,会比较目标和依赖文件的时间
    • 如果依赖的时间比目标的时间晚,需要重新生成目标
    • 如果依赖的时间比目标早,目标不需要更新,对应规则中的命令不需要被执行

变量

预定义的变量

AR :归档维护程序的名称,默认值 ar
CC : C 编译器的名称,默认值为 cc
CXX :C++ 编译器的名称,默认值为 g++
$@ :目标的完整名称
** < ∗ ∗ : 第 一 个 依 赖 文 件 的 名 称 ‘ <**:第一个依赖文件的名称 ` <^`:所有的依赖文件

获取变量的值

$(变量名)

函数

$(wildcard PATTERN ...)
  • 功能: 获取指定目录下指定类型的文件列表
  • 参数:PATTERN 指的是某个或多个目录下的对应的某种类型的文件,如果有多个目录,一般使用空格间隔。
  • 返回:得到的若干个文件的文件列表,文件名之间使用空格间隔
  • 示例:$(wildcard *.c ./sub/*.c) 返回值格式:a.c b.c c.c d.c e.c .f.c
$(patsubst <pattern>,<replacement>,<text>)
  • 功能:查找 中的单词(单词以空格、tab 或者回车、换行 分隔) 是否符合模式 pattern ,如果匹配的话,则以 replacement 替换。
  • pattern 可以包括通配符 % , 表示任意长度的字符串。如果 replacement 中也包含 % ,那么 ,replacement 中的这个 % 将是 pattern 中的那个 % 所代表的字串,可以用 \ 来转义,以\% 来表示真实含义的 % 字符
  • 返回:函数返回被替换过后的字符串
  • 示例 :$(patsubst %.c,%.o, x.c bar.c) 返回格式: x.o bar.o
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值