首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

Makefile解释。理解别人的Makefile

Makefile是一种用于构建和管理软件项目的文件,它包含了一系列规则和指令,用于指导编译器和链接器等工具进行代码的编译、链接和构建。Makefile通常用于C/C++项目,但也可以用于其他编程语言的项目。

Makefile的主要作用是自动化构建过程,它可以根据源代码文件的依赖关系和规则,判断哪些文件需要重新编译,从而提高编译效率。通过Makefile,开发人员可以定义编译选项、链接选项、目标文件、源文件、头文件路径等,以及编译、链接和清理等操作。

理解别人的Makefile需要注意以下几个方面:

  1. 目标和依赖关系:Makefile中的规则通常由一个目标和其所依赖的文件组成。目标是指需要生成的文件,依赖是指生成目标文件所需要的源文件或其他目标文件。通过定义目标和依赖关系,Makefile可以自动判断哪些文件需要重新编译。
  2. 规则和指令:Makefile中的规则由目标、依赖和指令组成。指令是指执行的具体命令,可以是编译命令、链接命令或其他自定义命令。通过定义规则和指令,Makefile可以告诉编译器和链接器如何进行编译和构建。
  3. 变量和函数:Makefile支持定义变量和使用函数。变量可以用于存储常用的编译选项、链接选项等,以便在多个规则中复用。函数可以用于处理字符串、路径等,以便在Makefile中进行更灵活的操作。
  4. 隐含规则:Makefile中可以使用隐含规则来简化编译过程。隐含规则是一组预定义的规则,用于根据文件的后缀名自动推导编译和链接命令。通过使用隐含规则,可以减少Makefile的编写工作量。

在腾讯云中,可以使用云原生产品Kubernetes来部署和管理容器化的应用程序。Kubernetes提供了强大的容器编排和管理能力,可以帮助开发人员更方便地构建、部署和扩展应用程序。您可以通过以下链接了解更多关于腾讯云Kubernetes的信息:https://cloud.tencent.com/product/tke

总结:Makefile是一种用于构建和管理软件项目的文件,通过定义规则和指令,可以自动化编译、链接和构建过程。它可以提高编译效率,简化项目管理。在腾讯云中,可以使用云原生产品Kubernetes来部署和管理容器化的应用程序。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

Makefile 使用

请参考 Visual Studio:修改源文件或头文件,只需要重新编译牵涉到文件, 就可以重新生成 APP ② Makefile 其实挺简单 一个简单 Makefile 文件包含一系列“规则”...在 Makefile 文件中确定要编译文件、目录,比如: obj-y += main.o obj-y += a/ “Makefile”文件总是被“Makefile.build”包含。 B....但是并非所有的目标都有依赖,例如,目标“clean”作用是清除文件,它没有依赖。 规则一般是用于解释怎样和何时重建目标。make 首先调用命令处理依赖,进而才能创建或更新目标。...当然,一个规则也可以是用于解释怎样和何时执行一个动作,即打印提示信息。 一个 Makefile 文件可以包含规则以外其他文本,但一个简单 Makefile 文件仅仅需要包含规则。...下面以 options 程序 Makefile 作为例子进行演示,Makefile 内容如下: File: Makefile 01 src := $(shell ls *.c) 02 objs :=

4.3K42

makefile中伪目标的理解

我们知道Makefile语法是这样: target ... : prerequisites ... command … … 2....Test: a.o b.o   gcc -o Test a.o b.oclean:  rm *.o 我们可以单独这么运行: make a.o 或者 make b.o 或者 make clean 注意上面三个区别...前两个都会生成目标,而第三个不会生成目标,仅仅希望执行所在规则(clean)定义命令(rm)。 这个时候就需要伪目标出马了:目的不是为了生成目标,仅仅是希望执行其所在规则定义后面的命令。 3....为什么要使用伪目标: 1)避免在我们Makefile中定义只执行命令目标和工作目录下实际文件名字出现冲突。...(比如,假如当前目录有一个clean文件,那么上面的 make clean 就不能达到我们预期了) 2)提高执行效率,被声明为伪目标后,make在执行此规则时不会视图去查找隐含规则来创建这个目标。

1.5K80

makefileinclude作用(makefile变量)

mkdir test $ cd test $ mkdir sub 在test下,建立a.c和b.c2个文件,在sub目录下,建立sa.c和sb.c2 个文件 建立一个简单Makefile...或者可以使用 obj=$(dir:%.c=%.o) 效果也是一样。 这里用到makefile替换引用规则,即用您指定变量替换另一个变量。...它标准格式是 $(var:a=b) 或 ${var:a=b} 它含义是把变量var中每一个值结尾用b替换掉a 今天在研究makefile时在网上看到一篇文章,介绍了使用函数...SRC = $(wildcard *.c) $(wildcard inc/*.c) 也可以指定汇编源程序: ASRC = $(wildcard *.S) 这样一来,makefile...使用变量替换引用将变量“foo”以空格分开值中所有的字尾字符“o”替换为“c”,其他部分不变。

3.2K50

Makefile伪目标

1、Makefile伪目标的格式: .PHONY : clean clean:     rm xxxx 2、Makefile伪目标的作用: 第一种情况: 如果我们需要书写这样一个规则:规则所定义命令不是去创建目标文件...,而是通过make命令行明确指定它来执行一些特点命令,就像例题中clean。...当文件夹中没有clean这个文件时候,我们输入“make clean”能按照初衷执行,但是一旦文件夹中出现clean文件,我们再次输入“make clean”,由于这个规则没有任何依赖文件,所以目标被认为是最新而不去执行规则所定义命令...直接执行rm动作; 第二种情况: 伪目标的另一种使用场合时在make并行和递归执行过程中。...,没有用到make对目录并行处理功能。

1.3K70

Linux — Makefile学习笔记以及多级目录下Makefile编写

Makefile文件文件内容来执行大量编译工作,Make将只编译改动代码文件,而不用完全编译。...Makefile文件一般和项目的其他源文件放在同一个目录下。在机器上可以同时存在许多不同makefile文件,如果一个大项目,可以用多个不同makefile文件来分别管理项目的不同部分。...如果未使用这个选项,标准版make命令将优先在当前命令下查找名称为makefile文件,如果不存在名称makefile文件,则开始查找名为Makefile文件。...三、Makefile宏 可以通过KEY=value在makefile中定义宏。...p $(SUBDIR) $(BINDIR) $(SUBDIR):RUN make -C $@ RUN: clean: rm -rf $(OBJDIR)/*.o $(BINDIR) 在这里简单解释一下

5.1K10

gdb和makefile讲解

2.6 跳行 until X行号:跳至X行 breaktrace(或bt):查看各级函数调用及参数 Linux项目自动化构建工具-make/Makefile 1 make/makefile背景 会不会写...makefile,从一个侧面说明了一个人是否具备完成大型工程能力 一个工程中源文件不计数,其按类型、功能、模块分别放在若干个目录中,makefile定义了一系列规则来指定,哪些文件需要先编译,哪些文件需要后编译...,哪些文件需要重新编译,甚至于进行更复杂功能操作 makefile带来好处就是——“自动化编译”,一旦写好,只需要一个make命令,整个工程完全自动编译,极大提高了软件开发效率。...make是一个命令工具,是一个解释makefile中指令命令工具,一般来说,大多数IDE都有这个命令,比如:Delphimake,Visual C++nmake,Linux下GNUmake。...在默认方式下,也就是我们只输入make命令: 1. make会在当前目录下找名字叫“Makefile”或“makefile文件。 2.

8710

可移植 Makefile 教程

在我写 Makefile 头 10 年里,我养成了一个非常不好习惯 -- 完全严格使用 GNU Make 扩展名。...本指南不仅适用于之前从来没有写过 Makefile make 初学者,同样适用于想要学习如何写出可移植 Makefile 资深开发者。...但不管怎样,为了能够理解文中示例,你必须首先对命令行(编译器,链接器,目标文件等等)构建程序常规步骤十分熟悉。我不会建议使用任何花哨技巧,也不会提供任何标准初学者模板。...Recursive Makefiles 当你项目被分为几个子目录,你可能会试图在每个子目录下放一个 Makefile ,然后递归调用。 不要使用递归 Makefile。...它会在几个分离 make 实例之间打破依赖树,并且常常会产生脆弱构建。使用递归 Makefile 毫无益处。好选择是在项目的根目录放置一个 Makefile, 在那里进行调用。

1.3K10

Makefile中:=, =, ?=和+=含义

Makefile语法中,时不时会见到各种“=”号赋值语句,除了常见“=”和“:=”,还有“?=”等 那么这些赋值等号分别表示什么含义呢?...“=” “=”是最普通等号,然而在Makefile中确实最容易搞错赋值等号,使用”=”进行赋值,变量值是整个makefile中最后被指定值。...不太容易理解,举个例子如下: VIR_A = A VIR_B = $(VIR_A) B VIR_A = AA 经过上面的赋值后,最后VIR_B值是AA B,而不是A B。...在make时,会把整个makefile展开,拉通决定变量值 “:=” 相比于前面“最普通””=”,”:=”就容易理解多了。”:=”就表示直接赋值,赋予当前位置值。...= new_value 这种情况下,VIR值就是old_value “+=” “+=”和平时写代码理解是一样,表示将等号后面的值添加到前面的变量上

1.1K20

多文件目录Makefile写法

多文件目录Makefile写法 1、前言   linux下程序开发,涉及到多个文件,多个目录,这时候编译文件任务量比较大,需要写Makefile 2、简单测试   测试程序在同一个文件中,共有func.h...也就是说通常将文件按照文件类型放在不同目录当中,这个时候Makefile需要统一管理这些文件,将生产目标文件放在目标目录下,可执行文件放到可执行目录下。测试程序如下图所示: ?...完整Makefile如下所示: 1 DIR_INC = ./include 2 DIR_SRC = ./src 3 DIR_OBJ = ./obj 4 DIR_BIN = ....: (1)Makefile 符号 @, ^, < 意思:  ^ 表示所有的依赖文件  < 表示第一个依赖文件   (2)wildcard、notdir、patsubst意思:   wildcard...附:我makefile: ######################################## #makefile ####################################

3.7K20

Makefile详细介绍和使用

makefile详细介绍和使用 Makefile定义规则 参考链接1:https://seisman.github.io/how-to-write-makefile/invoke.html 参考链接2:...https://www.cnblogs.com/LittleHann/p/3855905.html 规则是makefile中最重要概念,其告诉make 目标文件依赖关系,以及如何生成及更新这些目标文件...在makefile文件规则有2种,一种是显式规则,另一种是隐式规则。...:为要生成或更新目标 prerequisites:为目标依赖关系 recipe:为生成目标的命令, foo.o : foo.c defs.h cc -c -g foo.c 其中foo.o为target...上面的代码在linux命令窗口下输入make命令就可以执行了,最终会生成一个test可执行文件。如果需要清除生成中间.o文件,输入make clean就可以全部清除了。

58140

通用Makefile使用及解析

前言 欣赏一下韦东山老师写通用 Makefile 源码,韦东山老师“通用 Makefile” 是参考内核 Makefile 编写出来,这个通用 Makefile 可以在工作中方便使用。...一、源码使用 1、工程预览 使用 tree 命令查看文件树形结构 example 目录下文件为待添加 Makefile 源码,Makefile_and_readme 目录下文件为通用 Makefile...在工程里面添加 Makefile 可以参考 ./Makefile_and_readme/说明.txt 说明.txt 本程序 Makefile 分为3类: 1. 顶层目录 Makefile 2....四、怎么使用这套 Makefile: 1.把顶层 Makefile, Makefile.build 放入程序顶层目录 在各自子目录创建一个空白 Makefile 2.确定编译哪些源文件.../general_Makefile/example 因此,这样从顶层目录 Makefile 一路往下查看,你要编译 main.o sub.o 还有 a 目录下文件,再从 a 目录下 Makefile

45320

makefile 指定文件生成目录

大家好,又见面了,我是你们朋友全栈君。 1.上一篇博客虽然简单实现了自动处理依赖关系,但是生成各种临时文件都混在一起,太乱了。...假定我们源文件放在src目录,头文件放在inc目录,.o文件放在obj目录,.d文件放在dmk目录,Makefile和上述4个目录为同一级别。...c替换成.o,即a.o b.o addprefix表示增加前缀$(D_OBJ)/,则OBJ_C变量表示为obj/a.o obj/b.o 4.明白了上述语句之后我们可以把makefile写成如下状态 D_SRC...,clean就不需要解释了。...5.vpath 自动变量使用,第一个参数是查找类型,第二个是查找目录 vpath %.c src #查找依赖时如果遇到%.c,则自动到src目录下寻找 D_SRC = src D_INC = -I

3.8K20

Makefile中部分函数使用

notdir 把展开文件路径去掉,只显示文件名而不包含其路径信息,例如: FILES =(notdir (SOURCES)) 这行作用是把上面以 .c 结尾文件文件列表中附带路径去掉,只显示符合条件文件名...patsubst ( patten substitude, 匹配替换缩写)函数。它需要3个参数:第一个是一个需要匹配式样,第二个表示用什么来替换它,第三个是一个需要被处理由空格分隔字列。...参考文献 Makefile中foreach函数使用方法:https://blog.csdn.net/yanlaifan/article/details/71402771 Makefile中wildcard...、notdir、patsubst函数用法:https://blog.csdn.net/zqj6893/article/details/9066225 Makefilewildcard用法:Makefile...: Frytea Title: Makefile中部分函数使用 Link: https://blog.frytea.com/archives/466/ Copyright: This work

1.3K40

MakefileShell脚本简介

给很多刚接触Makefile的人: 1、Makefile中可以嵌入shell脚本,而且能像shell脚本中一样,各种命令、控制结构都可使用。 2、Makefile主要结构是 ......只有在command位置shell脚本才是有效,也就是只有在“生成目标的规则处”写shell脚本才是shell脚本,其它位置shell都是无效。...3、Makefileshell,不同行在不同进程中执行,不同行直接不能传递变量,所以很多时候shell都尽量使用反斜杠()来把相关内容串成一行。...4、Makefile变量和shell变量是两个不同东西,并且为了避免Makefile变量和shell变量冲突,引用Makefile变量最好使用$(Makefile_Var),引用shell变量时最好使用...5、Makefile多字符变量只能使用$(VAR)或${VAR}来引用,不能使用$VAR,$VAR会被解释成$(V)AR.

2K80
领券