首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

makefile变量赋值

大家好,又见面了,我是全栈君 在定义变量的值时,我们可以使用其它变量来构造变量的值,在Makefile中有两种方式来在用变量定义变量的值。...这种方法使用的是“:=”操作符,如: x := foo y := $(x) bar x := later 其等价于: y := foo bar x := later 值得一提的是,这种方法,前面的变量不能使用后面的变量...“MAKELEVEL”,其意思是,如果我们的make有一个嵌套执行的动作(参见前面的“嵌套使用make”),那么,这个变量会记录了我们的当前Makefile的调用层数。...因为在操作符的右边是很难描述一个空格的,这里采用的技术很管用,先用一个 Empty变量来标明变量的值开始了,而后面采用“#”注释符来表示变量定义的终止,这样,我们可以定义出其值是一个空格的变量。...还有一个比较有用的操作符是“?=”,先看示例: FOO ?

1.3K20
您找到你想要的搜索结果了吗?
是的
没有找到

makefile

前言 这几天的实验让我觉得有必要学习一下makefile 参考博客:博客 会不会写makefile,从一个侧面说明了一个人是否具有完成大型工程的能力 makefile带来的好处是自动化编译 规则...输入 make clean 才可以执行 变量 出于对makefile的易维护性的考虑,引入了变量的概念: objects=main.o kbd.o command.o display.o \ insert.o...读入被include的其它Makefile。 初始化文件中的变量。 推导隐晦规则,并分析所有规则。 为所有的目标文件创建依赖关系链。 根据依赖关系,决定哪些目标要重新生成。 执行生成命令。...文件,上级的makefile变量可以传到下一级: export ; 传递所有变量的话只需一个export,不需要任何变量名称 变量 变量可以使用变量: foo=$(bar)bar=$(ugh...firstowrd 返回字符串的第一个单词 文件名操作函数暂略

1K20

makefile

Makefile是按照某种脚本语法编写的文本文件,而GNU make能够对Makefile中指令进行解释并执行编译操作。...Makefile文件定义了一系列的规则来指定哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作。...(2)变量定义:在Makefile中可以定义一系列的变量变量一般都是字符串,当Makefile被执行时,变量的值会被扩展到相应的引用位置上。...2.1 Makefile中的变量 (1)Makefile中定义的变量,与C/C++语言中的宏一样,代表一个文本字串,在Makefile被执行时候变量会自动地展开在所使用的地方。...比较这两种操作,写出你的结论。同时指出$^ 、$@、$<在上述Makefile中的含义。

1.9K00

makefile 基础、进阶及常用 makefile

gcc main.o add.o sub.o mul.o -o app makefile 变量 接下来我们引入 makefile 变量机制,来修改一下上面的 makefile 文件。...,注意变量在使用的时候要加 $(),中间变量名字。...makefile 自动变量 makefile 中有一些预定义的变量,你可以理解它像是 C 语言中的一些关键字,分别有不同的意义,我们列举几个常用的自动变量(其他还有很多),通过上面的 makefile...如下所示: # 获取所有 .c 文件的列表赋值给 src 变量 src = $(wildcard *.c) # 根据 src 变量获取 .o 文件列表存放到 obj 变量中 obj = $(patsubst...我们也可以添加一些自定义的变量,让以后 makefile 维护起来更方便: # 获取所有 .c 文件的列表赋值给 src 变量 src = $(wildcard *.c) # 根据 src 变量获取 .

30910

Makefile总结

变量在声明时赋予初值,引用变量时需要在变量名前加上”$”符号,用小括号”()”或大括号”{}”把变量括起来。...: $@ 目标文件 $^ 依赖项列表 $< 依赖项列表第一项 通过make -p可以查看很多自定义的变量,如CC(默认值为cc),RM(默认值为rm -f) 可对上述的Makefile再进行修改: CC...并没有执行删除操作。 这种情况可以使用伪目标来解决,可避免在makefile中定义的执行命令目标和当前目录下实际文件名冲突。 一旦定义为伪目标,make执行规则不会去查找隐含规则,同样也提高了效率。...在调用子目录Makefile,有时我们需要传递参数,两种方法: 方法一: 在上层Makefile中使用”export”关键字对要传递的变量进行声明。...export DIR = /var/log 相反如不希望传递变量,可以使用”unexport”关键字 方法二: 在调用子Makefile命令上指定变量

91910

【Linux操作系统】自动化编译make和Makefile

文章目录 一.make/makefile简介 1.什么是make,makefile? 2.为什么要有make/makefile?...一.make/makefile简介 1.什么是make,makefile? make是一个构建C++项目的工具/命令;makefile是一个包含编译命令的脚本文件。...通过make工具解释makefile文件中的命令,进行我们的项目编译。 2.为什么要有make/makefile?...3.伪目标 介绍伪目标前我们先讲一讲实目标的概念: 实目标:命令执行后真正要生成的文件名, test就是实目标 伪目标:命令执行后不会生成实际文件,常用于辅助操作, .PHONY是伪目标的标注符...伪目标的特点:伪目标可以总是被执行[为什么后面讲] 4.其他规则 变量名 含义 $@ 目标文件,可表示test $^ 所有的依赖文件,可表示test.c $< 第一个依赖文件 test:test.c

82240

跟我一起写Makefile:MakeFile介绍

在定义好依赖关系后,后续的那一行定义了如何生成目标文件的操作系统命令,一定要以一个tab键作为开头。记住,make并不管命令是怎么工作的,他只管执行所定义的命令。...所以,为了makefile的易维护,在makefile中我们可以使用变量makefile变量也就是一个字符串,理解成C语言中的宏可能会更好。...在Makefile中我们要定义一系列的变量变量一般都是字符串,这个有点像你C语言中的宏,当Makefile被执行时,其中的变量都会被扩展到相应的引用位置上。 文件指示。...include的语法是: include ; filename可以是当前操作系统Shell的文件模式(可以包含路径和通配符) 在include前面可以有一些空字符,但是绝不能是[Tab...环境变量 MAKEFILES 如果你的当前环境中定义了环境变量MAKEFILES,那么,make会把这个变量中的值做一个类似于include的动作。这个变量中的值是其它的Makefile,用空格分隔。

97820

makefile终极奥义

上述还只是简单的makefile,属于「显式规则」,那么为了优化makefile我们介绍「隐式规则」 makefile中使用变量Makefile中我们要定义一系列的变量变量一般都是字符串,这个有点...OBJ:=main.o #定义变量 #引用变量 ${OBJ} #使用变量 $(OBJ) #推荐使用 除了自己定义的变量之外makefile还提供了预定义的变量 在隐含规则中的命令中,基本上都是使用了一些预先设置的变量...顾名思义,它的参数应该就是操作系统Shell的命令。 $(shell ) 「举例」 SRC = $(shell find ....在Makefile中我们要定义一系列的变量变量一般都是字符串,这个有点像你C语言中的宏,当Makefile被执行时,其中的变量都会被扩展到相应的引用位置上。 函数。...其包主要介绍了三个函数,一个是提取工作目录下的所有.c文件列表,另外一个就是将提取的.c列表转换成.o列表,最后就是shell函数,可以执行任何shell操作. 注释。

1.3K30

Makefile 的使用

3.1.3 通用 Makefile 的解析 ① 零星知识点 A. make 命令的使用: 执行 make 命令时,它会去当前目录下查找名为“Makefile”的文件,并根据它的指示去执行操作,生成第一个目标...比如: A = $@ test: @echo $A 上述 Makefile 中,变量 A 的值在执行时才确定,它等于 test,是延时变量。...3.3 Makefile 文件里的赋值方法 变量的定义语法形式如下: immediate = deferred immediate ?...对于附加操作符+=,右边变量如果在前面使用(:=)定义为立即变量则它也是立即变量,否则均为延时变量。...; ‘file’ :变量‘variable’在 Makefile 中定义; ‘command line’ :变量‘variable’在命令行中定义; ‘override’ :变量‘variable

4.3K42

Kconfig与Makefile

毫不夸张地说,Kconfig和Makefile是我们浏览内核代码时最为依仗的两个文件。基本上,Linux内核中每一个目录下边都会有一个Kconfig文件和一个Makefile文件。...Kconfig和Makefile就是Linux Kernel迷宫里的地图。地图引导我们去认识一个城市,而Kconfig和Makefile则可以让我们了解一个Kernel目录下面的结构。...利用Kconfig和Makefile寻找目标代 就像利用地图寻找目的地一样,我们需要利用Kconfig和Makefile来寻找所要研究的目标代码。...接下来阅读Makefile文件。...Kconfig和Makefile很好的帮助我们定位到了所要关注的目标,就像我们到一个陌生的地方要随身携带地图,当我们学习Linux内核时,也要谨记寻求Kconfig和Makefile的帮助。

1.6K20
领券