By francis_hao Mar 2,2017
makefile
makefile一个很简单的例子如下,该实例完成在执行make时,将main.c编译成可执行文件main的功能。
各项的含义:
main |
目标 |
main.c |
目标的依赖文件 |
: |
目标与依赖的分隔符 |
gcc -o main main.c |
命令(一般是shell命令) |
make工作过程
在默认的情况下,输入make命令时,
- make在当前目录下按顺序读取GNUmakefile、makefile和Makefile。
- 若找到文件则再读取第一个目标,并只将此目标当作最终目标。
- 查看其后的依赖,若依赖存在且未改动过则退出,若依赖不存在则查看之后的目标是否含有此依赖,层层嵌套。依赖若均存在,执行之后的命令。
当然,可以在make之后指定目标,那么make则会直接去读取该指定的目标,下图展示该过程:
此例的makefile中有两个目标:first和second。
只执行make时,make只读取第一个目标first,此目标生成后,其后的目标second不会被处理,但是在make后指定目标second,则会只生成此目标。
伪目标
makefile的东西就这么多,这篇文档也就结束了。
本文由 刘英皓 创作,采用 知识共享 署名-非商业性使用-相同方式共享 3.0 中国大陆 许可协议进行许可。欢迎转载,请注明出处:
转载自:http://www.cnblogs.com/yinghao1991/
参考
【1】 跟我一起写Makefile 陈皓 http://blog.csdn.net/haoel/article/details/2886/
时间: 2024-11-10 01:24:24