首页
学习
活动
专区
圈层
工具
发布

makefile

前言 这几天的实验让我觉得有必要学习一下makefile 参考博客:博客 会不会写makefile,从一个侧面说明了一个人是否具有完成大型工程的能力 makefile带来的好处是自动化编译 规则...上述make的工作方式 make寻找名为makefile或者Makefile的文件 寻找第一个目标文件,上述例子edit为最终的目标文件 如果edit文件不存在,那么make会寻找edit后的.o文件,...的文件系统 如果你不想使用makefile或者Makefile的文件名,可以用make -f file,file是你的文件名。...makefile中包含其他makefile的指令如同c++ 一样: -include foo.make a.mk b.mk c.mk e.mk f.mk 减号仍然表示不管怎样报错都继续执行下去,上面的命令可以采用部分正则规则简化...: -include foo,make *,mk $(bar) 工作方式 读入所有的Makefile。

1.3K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    makefile 基础、进阶及常用 makefile

    联合编译 makefile 上面的例子只是一个最简单的 makefile 的使用方法,但实际项目里面不可能只有一个文件,实际可能是多个 .c .h 组成,像这样的项目,我们该如何通过 makefile...所以我们还需要制作一些其他的目标文件,那就是这些 .o 文件。...了,但是还不算完美,后面我们再引入其他 makefile 的特性,先在这个项目目录下执行一次 make 命令,看看编译的效果如何。...makefile 自动变量 makefile 中有一些预定义的变量,你可以理解它像是 C 语言中的一些关键字,分别有不同的意义,我们列举几个常用的自动变量(其他还有很多),通过上面的 makefile...% 的值是上面生成 app 所需的 main.o,所以解释以后的代码相当于下面这样: main.o:main.c gcc -c $< -o $@ 根据这条规则,生成出了 main.o 文件,其他

    77010

    Makefile

    Makefile基础 在Linux环境下,当我们输入make命令时,它就在当前目录查找一个名为Makefile的文件,然后,根据这个文件定义的规则,自动化地执行任意命令,包括编译命令。...**注意:**如果在修改文件内容,但是其他文件没有改变内容(Modify time)没有更新,则未改变的文件不会进行重新编译,可能会造成程序出现问题。...所以该规则会使*.c从第一个开始,逐个编译为对应的.o文件。 小结:隐式规则让Makefile更简洁,很多情况下不需要显式定义规则。 使用变量 赋值形式 = 这种赋值在解析时是延迟展开的。...:当源码文件发生变动时,重新运行依赖生成命令即可更新deps.d。...完善Makefile 通过上述方法,我们可以逐步完善一个Makefile。

    62510

    Makefile教程

    Windows环境开发人员,可能并未听说过Makefile,但是时时刻刻在使用Makefile来完成程序的编译,因为开发者并不需要手动编写Makefile,而是通过IDE自动生成。...2.语法规则 不同厂商的Makefile在语法上可能会有细微的出入,但Makefile的主线和核心是文件依赖。...这就是Makefile的规则。也就是Makefile中最核心的内容。 3.Makefile内容 Makefile里主要包含了五个东西:显式规则、隐晦规则、变量定义、文件指示和注释。 1.显式规则。...7.10如何使用shell脚本给Makefile变量赋值 Makefile可以内嵌shell脚本,但是在内嵌的shell脚本只能读取Makefile的变量,如何给Makefile变量赋值呢?...[5]Makefile中的shell语法 [6]多个文件目录下Makefile的写法 [7]Makefile里PHONY的相关介绍 [8]Makefile中关于all和.PHONY .

    4.5K53

    Makefile入门

    每个规则由一个目标文件、一个或多个依赖文件和一组命令组成,这些命令描述了如何从依赖文件生成目标文件。 Makefile的主要作用是简化或组织编译代码的过程,它可以帮助程序员自动化编译、链接和打包程序。...通过将整个项目分解为多个模块,并定义每个模块之间的依赖关系,当某个模块发生变化时,只需要重新编译该模块及其依赖的其他模块即可。这有助于减少手动操作和错误,并提高代码质量。...这些命令描述了如何从依赖文件生成目标文件。在Makefile中,命令部分需要有一定的缩进,可以是一行或多行,它们会依次执行。...这意味着,每次当你运行make targetb时,make不会尝试查找一个叫做targetb的文件并尝试运行它的命令,而是会执行与targetb` 关联的命令。...如果你运行 make targeta,它会首先运行 targetb 和 targetc 的命令,然后执行与 targeta 关联的命令,输出 "targeta"。

    56110

    跟我一起写Makefile:MakeFile介绍

    makefile的规则 在讲述这个makefile之前,还是让我们先来粗略地看一看makefile的规则。 target ... : prerequisites ......这就是makefile的规则。也就是makefile中最核心的内容。 说到底,makefile的东西就是这样一点,好像我的这篇文档也该结束了。呵呵。...要执行其后的命令(不仅用于clean,其他lable同样适用),就要在make命令后明显得指出这个lable的名字。...所以,为了makefile的易维护,在makefile中我们可以使用变量。makefile的变量也就是一个字符串,理解成C语言中的宏可能会更好。...上面就是一个makefile的概貌,也是makefile的基础,下面还有很多makefile的相关细节,准备好了吗?准备好了就来。 Makefile里有什么?

    1.2K20

    Makefile从入门到上手

    说白了,Makefile 就是用来管理项目的。 你见到的 xxx.mk 文件或者 Makefile 都统称为 Makefile 脚本文件。...命名只能为 makefile 或者是 Makefile,因为只有这两种命名方式才能被 make 命令识别。 二、示例源码 这里放出供下面 Makefile 基础规则中用来测试的源码。...目标就是指要干什么,或说运行 make 后生成什么,而依赖是告诉 make 如何去做以实现目标。在 Makefile 中,目标和依赖是通过规则(rule)来表达的。...add.c 为下面 add.c int add(int a, int b) { return a+b+1; } 此时,再使用 make,发现了问题 可以看到,只修改 add.c,但是编译的时候,其他...a.out $(obj) : %.o : %.c gcc -c $< -o $@ a.out : $(obj) gcc $^ -o $@ clean : -rm -rf $(obj) a.out 运行如下

    62630

    Makefile 的使用

    我们可以使用“-f”选项指定文件,不再使用名为“Makefile”的文件,比如: make -f Makefile.build 我们可以使用“-C”选项指定目录,切换到其他目录里去,比如: make -...变量的导出(export): 在编译程序时,我们会不断地使用“make -C dir”切换到其他目录,执行其他目录里的 Makefile。...一个 Makefile 文件可以包含规则以外的其他文本,但一个简单的 Makefile 文件仅仅需要包含规则。虽然真正的规则比这里展示的例子复杂,但格式是完全一样的。...运行“make clean”时,由于目标 clean 没有依赖,它的命令“rm -f hello”将被强制执行。...3.4.2 文件名函数 (1)$(dir names…) 抽取names...中每一个文件名的路径部分,文件名的路径部分包括从文件名的首字符到最后一个斜 杠(含斜杠)之前的一切字符。

    4.7K42

    makefile终极奥义

    什么是makefile?...那么, make会在当前目录下找名字叫“Makefile”或“makefile”的文件。...上述还只是简单的makefile,属于「显式规则」,那么为了优化makefile我们介绍「隐式规则」 makefile中使用变量 在Makefile中我们要定义一系列的变量,变量一般都是字符串,这个有点...Makefile中变量有四种定义(赋值)方式: 1,简单赋值( := ) 编程语言中常规理解的赋值方式,只对当前语句的变量有效(推荐使用) 2,递归赋值( = )赋值语句可能影响多个变量,所有目标变量相关的其他变量都受影响...└── mult.c └── sub ├── Makefile └── sub.c 示例程序的Makefile分为3类: 顶层目录的Makefile 顶层目录的Makefile.build

    1.6K30
    领券