Mafile补充学习1~2
2016-04-17 20:45
162 查看
《朱老师物联网大讲堂》学习笔记
学习地址:www.zhulaoshi.org
# 这里是注释,和shell一样,
@表示静默执行,即make的时候不回显命令的执行,
变量赋值,
=
最简单的赋值,
:=
一般也是赋值,与=的区别是什么呢?
A=abc
B=$(A)def
#B:=$(A)def,区别就体现在这里,上句是hhdef,这句是abcdef,
A=hh
即所赋的值是:=取的是前面最靠近的,=取的是最后面的值,
因此:=反而好用些,在大的文件中,=你得往后看多远啊。。。。是吧
?=
该变量前面未赋值,则执行该赋值,也可以理解为在这个变量没有被定义过,
+=
和C语言一样,一个小细节是,添加后和原来的内容之间有一个空格,
export
经过export导出就变成环境变量了,环境变量一般用大写,普通变量用小写,
环境变量整个工程所有makefile之间都可以共享的,因此要注意会不会挖坑,
Makefile中可能有一些是内部定义的环境变量,
比如 make CC=arm-linux-gcc,传了一个环境变量CC,值是arm-linux-gcc,
如果不能覆盖内部已经有的,我们传参做什么。
通配符
*
注意和%的区别,%是用于规则的,
?
[ ]
将中括号中的字符依次去匹配,
自动变量,
$@ 规则的目标文件名
$< 规则的依赖文件名
$^ 依赖的文件集合
学习地址:www.zhulaoshi.org
# 这里是注释,和shell一样,
@表示静默执行,即make的时候不回显命令的执行,
变量赋值,
=
最简单的赋值,
:=
一般也是赋值,与=的区别是什么呢?
A=abc
B=$(A)def
#B:=$(A)def,区别就体现在这里,上句是hhdef,这句是abcdef,
A=hh
即所赋的值是:=取的是前面最靠近的,=取的是最后面的值,
因此:=反而好用些,在大的文件中,=你得往后看多远啊。。。。是吧
?=
该变量前面未赋值,则执行该赋值,也可以理解为在这个变量没有被定义过,
+=
和C语言一样,一个小细节是,添加后和原来的内容之间有一个空格,
export
经过export导出就变成环境变量了,环境变量一般用大写,普通变量用小写,
环境变量整个工程所有makefile之间都可以共享的,因此要注意会不会挖坑,
Makefile中可能有一些是内部定义的环境变量,
比如 make CC=arm-linux-gcc,传了一个环境变量CC,值是arm-linux-gcc,
如果不能覆盖内部已经有的,我们传参做什么。
通配符
*
注意和%的区别,%是用于规则的,
?
[ ]
将中括号中的字符依次去匹配,
自动变量,
$@ 规则的目标文件名
$< 规则的依赖文件名
$^ 依赖的文件集合
相关文章推荐
- Linux/Unix环境下的Make和Makefile详解
- Linux Makefile与Shell的问题
- Python实现生成简单的Makefile文件代码示例
- (转)自动生成 Makefile 的全过程详解
- 我的 ARM+Linux 学习路线
- 开发学习记录之看门狗驱动
- 时钟+温度+遥控设置,综合时钟例子
- u-boot的Makefile分析
- 关于linux模块驱动简单的Makefile
- 编译单个驱动的Makefile文件。
- Linux下运行openwebos- -(转)
- Linux下运行openwebos- -(转)
- makefile完全教程
- BusyBox 简化嵌入式 Linux 系统
- Linux内核Makefile文件
- Linux内核的Makefile
- EGL 学习
- 嵌入式开发设计方法变化的背景
- Makefile 文件的相关知识(2)
- 嵌入式人才的发展方向