make工程管理器就是一个“自动编译管理器”,这里的“自动”是指它可以根据文件时间戳自动发现跟新过的文件而减小工做量,同时,他经过读入makefile文件的内容来执行大量编译工做。用户只须要使用一次简单的编译语句就能够了,大大提升了工程的实际效率。linux
先来想象一个案例,假设个人执行档里面包含了四个原始码档案,分别是 main.c haha.c sin_value.c cos_value.c 这四个档案,若是您想要让这个程序能够跑,那么就须要这样编译spa
[root@linux ~]# gcc -c main.c [root@linux ~]# gcc -c haha.c [root@linux ~]# gcc -c sin_value.c [root@linux ~]# gcc -c cos_value.c # 先以上面的动做制做出四个目标文件,而后再进行下面的动做: [root@linux ~]# gcc -o main main.o haha.o sin_value.o cos_value.o \ > -lm -L/usr/lib -L/lib # 这样就能够制做出 main 这个执行档啰!执行看看吧! [root@linux ~]# ./main HaHa! I'm the King of the world 0.706825 0.707388
若是能够的话,能不能一个步骤就给他完成上面全部的动做呢? 试看看在这个目录下创建一个 makefile 档案,内容以下:命令行
# 1. 先创建编译的规则 [root@linux ~]# vi makefile main: main.o haha.o sin_value.o cos_value.o gcc -o main main.o haha.o sin_value.o cos_value.o -lm # 注意:第二行的 gcc 以前是 <tab> 按键产生的空格喔! # 2. 尝试给他创建规则看看 [root@linux ~]# rm -f main *.o <==先将以前的目标文件去除 [root@linux ~]# make cc -c -o main.o main.c cc -c -o haha.o haha.c cc -c -o sin_value.o sin_value.c cc -c -o cos_value.o cos_value.c gcc -o main main.o haha.o sin_value.o cos_value.o -lm # 这个时候 make 会主动去读取 makefile 这个档案的内容, # 并根据内容直接去给他编译起相关的执行档啰! # 3. 若是再执行一次 make 会怎样?! [root@linux ~]# make make: `main' is up to date. # 看到了吧?!是否很方便呢?!
make 有这些好处:
• 简化编译时所须要下达的指令;code
• 若在编译完成以后,修改了某个原始码档案,则 make 仅会针对被修改了的档案进行编译,其它 的 object file 不会被更动;blog
• 后能够依照相依性来更新( update )执行档。 get
make的基本规则为:自动化
目标(target): 依赖条件 1 依赖条件 2 <tab> gcc -o 欲创建的执行文件 依赖条件 1 依赖条件 2
在makefile中包含三个要素:目标、依赖、命令。在makefile中只有一个最终目标,其余目标都是这个目标连带的。编译
目标(target)就是咱们想要创建的信息,而依赖条件就是具备相关性的 object files ,那创建执行文件的语法就是以 <tab> 按键开头的那一行!特别给他留意喔, 『命令列必需要以 tab 按键做为开头』才行! 他的规则基本上是这样的: class
• 在 makefile 当中的 # 表明批注;效率
• <tab> 须要在命令行的第一个字符;
• 标的(target)与相依档案(就是目标文件)之间需以『:』隔开。
makefile中可使用系统默认的自动化变量简化命令:
$^:表明全部的依赖条件。
$@:表明目标文件
$<:表明一个目标文件