makefile | makefile语法基础

makefile是为make指令提供信息的文件。make指令直接解析makefile。因此我们从make指令的起源谈起。

在开发大型项目时,上百个源文件的管理是个大问题,特别是应该按什么顺序编译这些文件。有人会说,这个问题好办啊,我写一个shell脚本按顺序执行所有的编译指令,让.s .o文件等按顺序生成,不就行了吗。这的确是一个解决的办法,但是呢,如果你真的把这个脚本用在大型项目上,会收到程序员们的投诉:我们用了这个脚本,每次改两行代码想看看效果就得编译半个小时,还不如我们从改动的文件开始手动编译呢。make工具就应程序员们的抱怨诞生了(情节纯属虚构,具体已不可考)。

make工具解决的问题正是大型项目源文件的管理问题。make的工作原理很好理解。之前我们提到把编译的指令按顺序保存在脚本里,就可以维护好源文件的编译顺序,但这样做带来的问题是重复编译。具体来说,重复编译就是指已经编译好的,没有被改动过的源文件又被重新编译了一次。make工具为了防止重复编译,采用的办法就是比较这些源文件和编译后的文件,看它们的版本是否一致,如果源文件(somefile.c)的版本比编译后的文件(somefile.o)新,就意味着需要重新进行编译。想要做这件事情,make文件需要知道两个信息:

  • Dependency: 产生目标文件所依赖的文件。比如目标文件为main.o,依赖的文件为main.cmain.h,那么依赖关系就写作
    main.o: main.c main.h
    
    再比如目标文件为可执行文件prog,需要通过链接filea.o, fileb.o, 和filec.o得到,那么依赖就写作
    prog: filea.o fileb.o filec.o
    
  • Command: 产生目标文件需要执行的指令。makefile里紧跟依赖关系(dependency)的是编译指令,这就和平常编译是一样的,需要执行的编译指令,需要用到的编译选项,需要用到的文件都应该在这里指明。比如,接着前面的两个例子,我们应该在makefile里面写
    main.o: main.c main.h
    gcc -c main.c
    
    prog: filea.o fileb.o filec.o
    gcc filea.o fileb.o filec.o -LS -o prog
    

依赖关系和指令是makefile里两个最重要的基础语法。之后我们会在这两个语法上发展变化。

下面是一个最基础的例子,其中的Makefile文件用上面提到的两种语法写成,就是我们这里说到的makefile。读者可以将所有的文件保存到同一个目录下,然后执行make,观察运行结果。(还没写)


Reference: 老李的地下室:Linux环境下make指令和makefile文件详解

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 来自陈浩的一片老文,但绝对营养。 示例工程:3 个头文件*.h,和 8 个 C 文件*.c。 初 编译过程,源文件...
    周筱鲁阅读 4,752评论 0 17
  • makefile关系到整个工程的编译规则,一个工程中的源文件不计其数,按其类型、功能、模块分别放在若干的目录当中,...
    Joe_HUST阅读 1,909评论 0 3
  • 第一章:编译和安装SCons第二章:简单编译第三章:编译相关的一些事情第四章:编译和链接库文件第五章:节点对象第六...
    仙灵儿阅读 12,035评论 0 3
  • 1.Makefile规范 target 这 一 个 或 多 个 的 目 标 文 件 依 赖 于prerequisi...
    G风阅读 1,949评论 0 3
  • 生命中总会遇到一个人,他的出现让你觉得之前的爱情都不值一提,会让你觉得他的到来是生命的恩赐,会让你变得勇敢变得无所...
    深巷梨花阅读 310评论 0 2