Makefile

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: Makefile

一、Makefile作用

多个文件,方便编译链接过程。

二、目标、依赖、命令

目标就是最终要生成的东西
依赖是用来生成目录的原材料
命令就是加工方法
make的过程其实就是使用命令将依赖加工成目标的过程

三、通配符%,*,?,[]

自动推导:就是Makefile的规则,当Makefile需要某一个目标时,他会把这个目标去套规则说明,一旦套上了某个规则说明,则Makefile会试图寻找这个规则中的依赖,如果能找到则会执行这个规则用依赖生成目标。

%一般只用于规则描述中,又叫做规则通配符

  • 若干个任意字符

? 1个任意字符
[] 将[]中的字符依次去和外面的结合匹配

四、定义和使用变量

定义和使用变量,和shell一样都没有变量类型,直接定义使用,引用变量时用$(var)

五、伪目标(.PHONY)

伪目标就是,单纯为了执行这个目标下面的命令,不会生成目标文件
伪目标一般都没有依赖,因为执行伪目标就是为了执行目标下面的命令
伪目标可以直接写,不影响使用,也可以在前面用.PHONY来明确声明它是伪目标。
.PHONY clean

clean:

    rm *.o -f

六、引用其他Makefile(include指令)

有时候Makefile总体比较复杂,因此分成好几个Makefile来写。然后在主Makefile中引用其他的,用include指令来引用。引用的效果也是原地展开,和C语言中的头文件包含相似。

七、@用来静默执行

在makefile的命令行中前面的@表示静默执行。
默认情况下在执行一行命令前,会先把这行命令给打印出来,然后再执行这行命令。
静默执行:不打印命令,直接执行这行命令

八、Makefile中几种变量赋值运算符

= 直接赋值,被解析时他的值取决于最后一次赋值时的值
:= 也是直接赋值,就地直接解析,只用往前看即可
不加:把全局最后赋值后的变量解析
加:就地解析

va=abc
vb=$(va)gef
va=qq
all:

    @echo $(vb)

把下面的qq解析赋值

xw@ubuntu:~/xiaowei/makefilexuexi$ make
qqgef

va=abc
vb:=$(va)gef
va=qq
all:

    @echo $(vb)

abc解析赋值

xw@ubuntu:~/xiaowei/makefilexuexi$ make
abcgef

?= 赋值过则执行这条赋值,如果前面已经赋值过了则本行被忽略
+= 用来给一个已经赋值的变量接续赋值,意思就是把这次的值加到原来的值的后面
中间自动加空格

九、Makefile的环境变量

export导出的就是环境变量。一般情况下要求环境变量名用大写,普通变量名用小写。
就是Makefile之间可以共享全局变量
Makefile中可能有一些环境变量可能是makefile本身自己定义的内部的环境变量或者是当前的执行环境提供的环境变量(譬如我们在make执行时给makefile传参。make CC=arm-linux-gcc,其实就是给当前Makefile传了一个环境变量CC,值是arm-linux-gcc。我们在make时给makefile传的环境变量值优先级最高的,可以覆盖makefile中的赋值)

十 、Makefile的自动变量

$@ 规则的目标文件名
$< 规则的依赖文件名
$^ 依赖的文件集合

目录
相关文章
|
6月前
|
存储 编译器 C++
Makefile
Makefile
34 0
|
6月前
Makefile伪目标
Makefile伪目标
44 0
|
Shell Linux Go
一日一技:5分钟掌握 Makefile
一日一技:5分钟掌握 Makefile
166 0
1.10~1.12 Makefile
1.10~1.12 Makefile
83 0
1.10~1.12 Makefile
|
Java C语言
Makefile2
规范 target可以是Object file, 可执行文件或者标签(标签一般没有依赖) 越靠近最终结果的target卸载越前面 定义target前, 定义CC, SRC, CFLAGS, OBJS, INCLUDES, RM, COPY等变量方便修改 在以前使用gcc编译时, 一般直接使用gcc编程链接成可执行文件, 但是在makefile中.
989 0
|
Linux C语言 编译器
makefile 中 $@ $^ %< 使用【转】
转自:http://blog.csdn.net/kesaihao862/article/details/7332528 这篇文章介绍在LINUX下进行C语言编程所需要的基础知识。在这篇文章当中,我们将会学到以下内容:源程序编译Makefile的编写程序库的链接程序的调试头文件和系统求助1.源程序的编译在Linux下面,如果要编译一个C语言源程序,我们要使用GNU的gcc编译器。
891 0
|
Shell vr&ar C语言
Makefile 使用总结【转】
转自:http://www.cnblogs.com/wang_yb/p/3990952.html#3372064 1. Makefile 简介 Makefile 是和 make 命令一起配合使用的.
752 0
|
Linux C++ C语言
Makefile第一讲:一个简单的Makefile
摘要 假定你对linux已经比较的熟悉,假定你编程已经稍有经验,本文不会对文章作出太多基础性解释,看不懂莫怪,只当作给学习的朋友一个引导思路,我也是一个初学者,边学边写,将学会的教给大家,文章有错误之处误导了朋友,请轻喷 makefile   假定你对linux已经比较的熟悉,假定你编程已...
837 0