关于Makefile的学习
2016-05-21 21:41
267 查看
首先,让我们先来简单的了解一下什么是Makefile?
一个工程中的源文件不计其数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为 makefile就像一个Shell脚本一样,其中也可以执行操作系统的命令。Linux 环境下的程序员如果不会使用GNU make来构建和管理自己的工程,应该不能算是一个合格的专业程序员。
在 Linux(unix )环境下使用GNU 的make工具能够比较容易的构建一个属于你自己的工程,整个工程的编译只需要一个命令就可以完成编译、连接以至于最后的执行。不过这需要我们投入一些时间去完成一个或者多个称之为Makefile 文件的编写。所要完成的Makefile 文件描述了整个工程的编译、连接等规则。其中包括:工程中的哪些源文件需要编译以及如何编译、需要创建那些库文件以及如何创建这些库文件、如何最后产生我们想要的可执行文件。
尽管看起来可能是很复杂的事情,但是为工程编写Makefile 的好处是能够使用一行命令来完成“自动化编译”,一旦提供一个正确的Makefile。编译整个工程你所要做的唯一的一件事就是在shell 提示符下输入make命令。整个工程完全自动编译,极大提高了效率。
现在我们来看一个简单的makefile:
LIB_NAME=vendor1
//定义变量名
all:shared static
//make目标all 存在有shared static 两个依赖
rm -f *.o //make目标all 下的动作
shared:
gcc -shared -fpic -o lib${LIB_NAME}.so *.c //目标shared下的动作
static:
gcc -c *.c
ar -rcs lib${LIB_NAME}.a *.o //目标static下的动作
clean:
rm -rf *.o
rm -rf *.a *.so //目标clean下的动作
install:
cp lib${LIB_NAME}.* ~/dd //目标install下的动作
那么makefile是怎么执行make的呢?
一般来说,makefile下的第一条目标为总目标,输入make时执行all目标,其目标下有shared和static依赖,那么首先跳到shared下执行shared目标的动作(也就是命令),再回到all中 发现还存在依赖,就接着到static目标下执行动作,持续执行依赖,直到完成all目标下的依赖,在接着完成all目标下的动作。
PS:①动作可是Linux下的命令,但是动作存在的一行的第一个字符必须是TAB键;
②目标下的依赖可以是文件(目录)或者是其他目标。
target: depend1 depend2 depend3 ...
[TAB] action1
[TAB ] action2
target1:
[TAB] action1
[TAB] action2
make后可以接目标作为命令:
关于make的一些选项:
make 找makefile或Makefile文件执行总的目标
make clean 执行makefile文件中的clean目标
make -C directory 进入到directory文件夹中去执行总的目标
make clean -c direcotry 进入到directory文件夹中去执行clean目标
make -f comm_makefile 通过-f选项指定一个makefile文件
make VAR=value 给Makefile传一个参数VAR,其值为value
一个工程中的源文件不计其数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作,因为 makefile就像一个Shell脚本一样,其中也可以执行操作系统的命令。Linux 环境下的程序员如果不会使用GNU make来构建和管理自己的工程,应该不能算是一个合格的专业程序员。
在 Linux(unix )环境下使用GNU 的make工具能够比较容易的构建一个属于你自己的工程,整个工程的编译只需要一个命令就可以完成编译、连接以至于最后的执行。不过这需要我们投入一些时间去完成一个或者多个称之为Makefile 文件的编写。所要完成的Makefile 文件描述了整个工程的编译、连接等规则。其中包括:工程中的哪些源文件需要编译以及如何编译、需要创建那些库文件以及如何创建这些库文件、如何最后产生我们想要的可执行文件。
尽管看起来可能是很复杂的事情,但是为工程编写Makefile 的好处是能够使用一行命令来完成“自动化编译”,一旦提供一个正确的Makefile。编译整个工程你所要做的唯一的一件事就是在shell 提示符下输入make命令。整个工程完全自动编译,极大提高了效率。
现在我们来看一个简单的makefile:
LIB_NAME=vendor1
//定义变量名
all:shared static
//make目标all 存在有shared static 两个依赖
rm -f *.o //make目标all 下的动作
shared:
gcc -shared -fpic -o lib${LIB_NAME}.so *.c //目标shared下的动作
static:
gcc -c *.c
ar -rcs lib${LIB_NAME}.a *.o //目标static下的动作
clean:
rm -rf *.o
rm -rf *.a *.so //目标clean下的动作
install:
cp lib${LIB_NAME}.* ~/dd //目标install下的动作
那么makefile是怎么执行make的呢?
一般来说,makefile下的第一条目标为总目标,输入make时执行all目标,其目标下有shared和static依赖,那么首先跳到shared下执行shared目标的动作(也就是命令),再回到all中 发现还存在依赖,就接着到static目标下执行动作,持续执行依赖,直到完成all目标下的依赖,在接着完成all目标下的动作。
PS:①动作可是Linux下的命令,但是动作存在的一行的第一个字符必须是TAB键;
②目标下的依赖可以是文件(目录)或者是其他目标。
target: depend1 depend2 depend3 ...
[TAB] action1
[TAB ] action2
target1:
[TAB] action1
[TAB] action2
make后可以接目标作为命令:
关于make的一些选项:
make 找makefile或Makefile文件执行总的目标
make clean 执行makefile文件中的clean目标
make -C directory 进入到directory文件夹中去执行总的目标
make clean -c direcotry 进入到directory文件夹中去执行clean目标
make -f comm_makefile 通过-f选项指定一个makefile文件
make VAR=value 给Makefile传一个参数VAR,其值为value
相关文章推荐
- UVA 11865 Stream My Contest(最小树形图+二分)
- [BZOJ1119][POI2009]SLO(置换)
- 【状态压缩DP】[2016"百度之星" - 初赛(Astar Round2A)]Sitting in Line
- 堆排序-----数据结构
- SparkR初探
- ios内存警告处理
- 堆排序-----数据结构
- iOS开发 ☞ UITextField 详解
- 华信第一阶段Java试卷分析
- 自定义裁剪图片
- We have a problem with promises
- 【杭电-oj】-2039-能否构成三角形
- libva中的H.264编码内存泄露问题
- Best Time to Buy and Sell Stock with Cooldown
- Volatile和Synchronized的原理
- 山东省第一届ACM程序设计大赛 Balloons (简单dfs)
- javascript农历
- pl/sal for循环
- java的几种设计模式
- zoj 1088 约瑟夫环问题(模拟)