文章目录

  • 前言
  • 一、环境变量(全局变量)
  • 二、目标变量(局部变量)
  • 三、模式变量
  • 总结


前言


一、环境变量(全局变量)

  1. Makefile 中的环境变量,是指在执行 Makefile 时,从外部传入 Make 命令的环境变量

python读makefile环境变量 makefile环境变量有哪些_linux

一些常用的 Makefile 环境变量:

  • MAKE:表示当前正在使用的 Make 工具的名称;
  • PWD:表示当前目录的绝对路径;
  • SHELL:表示当前 Shell 的名称。默认是 /bin/sh。可以通过定义 SHELL 变量来指定所使用的 Shell;
  • MAKEFLAGS:表示传递给 make 命令的所有参数。可以在 Makefile 中通过 $(MAKEFLAGS) 来引用它;
  • MAKELEVEL:表示 Make 命令嵌套的层数,从 0 开始计数。

环境变量可以在所有的 makefile 中使用。
但是,过多依赖于环境变量会导致代码移植性降低。

  1. 变量在不同的 makefile 之间进行传递:

(1). 直接在外部定义环境变量进行传递
(2). 使用 export 定义变量进行传递。(定义临时变量
(3). 定义 make 命令行变量进行传递

  1. 注意:
    如果 makefile 文件中 定义了同名变量,环境变量将会被覆盖
  • 运行 make 时,指定 " -e " 选项,优先使用环境变量。

示例:
makefile 文件:

export var := hello			# 使用 export 定义临时环境变量
new := world

test :
	@$(MAKE) -f makefile.1		 # 首次 进入 makefile.1 文件 执行命令
	@$(MAKE) -f makefile.1 new:=$(new)    # 再次 进入 makefile.1 文件,使用命令行进行变量传递。

makefile.1 文件:

test:
	@echo "var => $(var)"
	@echo "new => $(new)"

执行结果:

python读makefile环境变量 makefile环境变量有哪些_python读makefile环境变量_02


第一次进入 makefile.1 文件,只输出了 var 的值,而 new 为空。 因为 var 使用了 export 定义临时环境变量,则 可在 不同的 makefile 文件间传递。

第二次进入 makefile.1 文件,new 也输出了值,这次使用 命令行进行传递变量。

在 Makefile 中, $(MAKE) 是一个内置变量,它表示当前正在使用的 Make 命令的名称。这个变量可以保证在使用不同版本的 Make 工具或者在不同的操作系统中都能正确地工作。
如果在一个 Makefile 中调用另一个 Makefile,可以使用 -f 选项来指定目标 Makefile 文件的名称。

二、目标变量(局部变量)

python读makefile环境变量 makefile环境变量有哪些_python读makefile环境变量_03


作用域 只在 指定的目标连带规则 中。

示例:

var := hello				# 文件变量
test : var := world			# 定义目标变量 var 

test :	another				# 依赖于 another				
	@echo "test"
	@echo "var => $(var)"

another :
	@echo "another"
	@echo "var => $(var)"

python读makefile环境变量 makefile环境变量有哪些_python读makefile环境变量_04


test 目标 和其 another 依赖均打印出 world, 而不是 hello

文件变量在 makefile 中定义的变量,这个很好理解,即 作用域为 整个 makefile 文件。

三、模式变量

  • 模式变量 是 目标变量的扩展
  • 作用域只在 符合模式的目标及连带规则中
var := hello				

%e : override var := abc			# 定义模式变量

test :					 				
	@echo "test"
	@echo "var => $(var)"

rule :
	@echo "rule"
	@echo "var => $(var)"

python读makefile环境变量 makefile环境变量有哪些_运维_05


%e 表示 目标结尾 是 e 的可以执行 %e : override var := abc

test 不是以 e 结尾,而 rule 是以 e 结尾,则打印出 abc


总结

下一篇介绍 makefile 中的 条件判断语句