编译的过程需要½行好多动作啊!而且如果要重新编译,则上述的流程得要重新来一遍,光是找出这
些指令就够烦人的了!
如果可以的话,能不能一个步骤就给他完成上面所有的动作呢?那就利用
make
这个工具吧!
先试看看在这个目录下½立一个名为
makefile
的文件,内容如下:
# 1.
先
编辑
makefile
这个规则
文件,
内
容只要作出
main
这个执
行
档
[root@study ~]#
vim 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.
尝试
使用
makefile
制
订
的
规则½
行
编译
的行
为
:
[root@study ~]#
rm
-
f main *.o
<==
先
½
之前的目
标
文件去除
[root@study ~]#
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.
在不
删
除任何
文件
的情
况
下,重新
执
行一次
编译
的
动
作:
[root@study ~]#
make
make: `main' is up to date.
#
看到了吧!是否很方便呢!只
会½
行更新
(update)
的
动
作而已。
或许你会说:『如果我½立一个
shell script
来½上面的所有动作都集½在一起,不是具有同样的效
果吗?』呵呵!
效果当然不一样,以上面的测试为例,我们½写出
main
需要的目标文件,½果
make
会主动的去判断每个目标文件相关的原始码文件,并直½予以编译,最后再直½½行连½的动作!
真
的是很方便啊!此外,如果我们更动过某些原始码文件,则
make
也可以主动的判断哪一个原始码
与相关的目标文件文件有更新过,
并½更新该文件,如此一来,½可大大的½省很多编译的时间呢!
要知道,某些程序在½行编译的行为时,会消耗很多的
CPU
资源呢!所以说,
make
有这些好处:
.
简化编译时所需要下达的指令;
.
若在编译完成之后,修改了某个原始码文件,则
make
½会针对被修改了的文件½行编译,其他的
object file
不会被更动;
.
最后可以依照相依性来更新
(update)
执行档。
既然
make
有这么多的优点,那么我们当然就得好好的了½一下
make
这个令人关心的家伙啦!而
make
里面最需要注意的大概就是那个规则文件,也就是
makefile
这个文件的语法啦!所以底下我
们就针对
makefile
的语法来加以½绍啰。