当前位置: 首页 > news >正文

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
http://www.lryc.cn/news/28553.html

相关文章:

  • 【数据结构初阶】手撕单链表
  • angular中http请求和传值
  • VSCode问题记录
  • html基础学习
  • leetcode_贪心算法
  • C语言每日一题】——杨氏矩阵
  • 最佳iOS设备管理器imazing 2.16.9官网Mac/Windows下载电脑版怎么下载安装
  • 八大排序算法之堆排序的实现+经典TopK问题
  • 使用AppSmith(PagePlug )低代码平台快速构建小程序应用实践
  • 第52章 短信验证服务和登录的后端定义实现
  • 谷歌验证码的使用
  • Git学习入门(1)- git的安装与配置
  • 【Python】使用Playwright断言方法验证网页和Web应用程序状态
  • libgdx导入blender模型
  • 【20230227】回溯算法小结
  • centos安装rocketmq
  • 汇编语言程序设计(二)之寄存器
  • 华为OD机试Golang解题 - 单词接龙 | 独家
  • Elasticsearch的搜索命令
  • 为什么人们宁可用Lombok,也不把成员设为public?
  • 【Redis】Redis 如何实现分布式锁
  • C++ 断言
  • C++修炼之练气期第五层——引用
  • 从企业数字化发展的四个阶段,看数字化创新战略
  • vulnhub five86-1
  • 28个案例问题分析---01---redis没有及时更新问题--Redis
  • [1.3_3]计算机系统概述——系统调用
  • Vue基础学习 第一个Vue程序 el挂载点 v-指令(1)
  • 前端页面性能
  • 2023-03-04 反思