Makefile编写 程序的编译和链接 使用C、C++编写可执行文件,首先要把源文件编译成中间代码文件,Linux下是.o文件,即Object File,这个动作叫做编译(complie)。...于是Makefile闪亮登场。 Makefile确定整个工程的编译规则,只需要一个make命令,就可以实现“自动化编译”。...这就是Makefile的规则,也就是Makefile中最核心的内容。..." 或 "makefile"的文件。...所以,为了makefile的易维护,在makefile中我们可以使用变量。makefile的变量也就是一个字符串。可以理解为C语言中的宏。
这就是Makefile的规则。也就是Makefile中最核心的内容。...test.o: test.c test.h gcc –c test.c 注意,第一个字符为#的行表示注释行。...第一个非注释行指定 test.o 为目标,并且依赖于 test.c 和 test.h 文件。随后的行指定了如何从目标所依赖的文件建立目标。...2、Makefile的基本内容 Makefile一般包括包含:显式规则、变量定义、隐含规则、文件指示和注释等五个内容。 (1)显式规则:显式规则说明如何生成一个或多个的目标文件。...(5)注释:Makefile中只有行注释,和UNIX的Shell脚本一样,其注释是用“#”字符,如果你要在你的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。
联合编译 makefile 上面的例子只是一个最简单的 makefile 的使用方法,但实际项目里面不可能只有一个文件,实际可能是多个 .c .h 组成,像这样的项目,我们该如何通过 makefile...gcc main.o add.o sub.o mul.o -o app makefile 变量 接下来我们引入 makefile 变量机制,来修改一下上面的 makefile 文件。...makefile 自动变量 makefile 中有一些预定义的变量,你可以理解它像是 C 语言中的一些关键字,分别有不同的意义,我们列举几个常用的自动变量(其他还有很多),通过上面的 makefile...makefile 中的 all 因为 makefile 的执行流程是找到第一个目标作为最终生成的目标,如果顺序错乱了,makefile 就可能报错,all 方法就是解决这个问题而存在的,并且,all 方法可以让一个...至此 makefile 的功能说明到此为止一,下面就是收集的一些常用做测试用的 makefile 代码。
Makefile包含 目标文件、依赖文件、可运行命令三部分。 ...整个Makefile文件都是这样的格式。...参考链接: https://blog.csdn.net/haoel/article/details/2886 Makefile 伪目标: https://www.cnblogs.com/hnrainll
#一个通用的Makefile,可以在linux各大平台下通用编译c程序,这个版本在gcc平台下实现,如需要课更改第二部的gcc,也可以在第三部添加所需要的库,如有错误,欢迎即使纠正 #1.遵循可移植操作系统接口
下做C/C++开发时经常用到,会写Makefile是程序员的必备技能。...test.o: test.cpp test.h g++ -c test.cpp -o test.o clean: rm *.o helloworld 注释...行前面加”#”号,如#g++ main.o test.o -o helloworld 表示注释了该行 变量 变量在声明时赋予初值,引用变量时需要在变量名前加上”$”符号,用小括号”()”或大括号”{}...通过主目录下的Makefile分别管理各个目录下的Makefile编译。这就要用到嵌套执行。...在调用子目录Makefile,有时我们需要传递参数,两种方法: 方法一: 在上层Makefile中使用”export”关键字对要传递的变量进行声明。
title: Makefile文件 文章目录 title: Makefile文件 Makefile文件 Makefile文件 make命令执行时,需要一个makefile文件,以告诉make命令需要怎么样的去编译和链接程序
函数 Makefile 里的函数跟它的变量很相似——使用的时候,你用一个 $ 符号跟开括号,函数名,空格后跟一列由逗号分隔的参数,最后用关括号结束。
在Makefile中可以使用函数来处理文本,从而让我们的命令或是规则更为灵活和智能。make所支持的函数也不算很多,不过已经足够我们的操作了。函数调用后,函数的返回值可以当做变量来使用。...makefile:3: *** error is "can't find commad g++"....注意:该函数在执行时会对它的参数进行两次展开,第一次展开是由 eval 函数本身完成,第二次是函数展开后的结果被作为 makefile 内容时由 make 解析时展开。...示例: 假设有以下makefile。...---- 参考文献 [1]Makefile经典教程(掌握这些足够) [2]GNU make manual
这就是Makefile的规则。也就是Makefile中最核心的内容。 3.Makefile内容 Makefile里主要包含了五个东西:显式规则、隐晦规则、变量定义、文件指示和注释。 1.显式规则。...5.注释。Makefile中只有行注释,和Linux的Shell脚本一样,其注释是用“#”字符,这个就像C/C++中的“//”一样。...如果你要在你的Makefile中使用“#”字符,可以用反斜框进行转义,如:“#”。 如果想多行注释的话,在注释行的结尾加行反斜线(\),下一行也被注释,这样就是可以实现多行注释了。...很显然,Makefile的这多行注释的方法没有像C/C++的多行注释方法/*注释*/方便。...注释方式。
# 一、Makefile简介 # 1、Makefile是什么 Makefile是一种用于自动化构建程序的工具,它提供了一系列规则来指定源代码文件之间的依赖关系,以及如何生成目标文件。...当我们在命令行中输入make命令时,Make会查找当前目录下是否存在名为Makefile或makefile的文件。...# 二、Makefile 三要素 Makefile的三个要素是目标、依赖和命令。...$@ # 因为.o文件默认使用.c文件来进行编译,所以可以注释以下两行 #%.o:%.c # ${CC} -c $< -o $@ .PHONY:clean clean:...# 五、Makefile的条件分支 # vim Makefile ARCH ?
什么是makefile?...上述还只是简单的makefile,属于「显式规则」,那么为了优化makefile我们介绍「隐式规则」 makefile中使用变量 在Makefile中我们要定义一系列的变量,变量一般都是字符串,这个有点...隐晦规则」、「变量定义」、「函数」、「注释」。...注释。Makefile中只有行注释,和UNIX的Shell脚本一样,其注释是用 # 字符,这个就像C/C++中的 // 一样。...└── mult.c └── sub ├── Makefile └── sub.c 示例程序的Makefile分为3类: 顶层目录的Makefile 顶层目录的Makefile.build
最简单的 Makefile 文件如下: hello: hello.c gcc -o hello hello.c clean: rm -f hello 将上述 4 行存为 Makefile 文件(注意必须以...3.1 配套视频内容大纲 3.1.1 Makefile 规则与示例 参考文档:gunmake.htm ① 为什么需要 Makefile 怎么高效地编译程序? 想达到什么样的效果?...③ 先介绍 Makefile 的 2 个函数 A....在 Makefile 文件中确定要编译的文件、目录,比如: obj-y += main.o obj-y += a/ “Makefile”文件总是被“Makefile.build”包含的。 B....下面以 options 程序的 Makefile 作为例子进行演示,Makefile 的内容如下: File: Makefile 01 src := $(shell ls *.c) 02 objs :=
# 指定编译工具 CC=g++ # 依赖库 LIB=-lmysqlclient \ -I/usr/include/mysql/ \ -L/usr...
Makefile 简介 Makefile 是和 make 命令一起配合使用的...., 文件指示, 注释) Makefile基本格式如下: target ... : prerequisites ......中定义的变量 文件指示 :: Makefile中引用其他Makefile; 指定Makefile中有效部分; 定义一个多行命令 注释 :: Makefile只有行注释 "#", 如果要使用或者输出..."#"字符, 需要进行转义, "\#" 1.2 GNU make 的工作方式 读入主Makefile (主Makefile中可以引用其他Makefile) 读入被include的其他Makefile...Makefile 高级语法 3.1 嵌套Makefile 在 Makefile 初级语法中已经提到过引用其它 Makefile的方法.
Makefile学习2 Makefile条件判断 使用条件判断,可以让make在编译程序时,根据不同的情况,执行不同的分支:可以执行不同的命令,使用不同的编译参数,生成不同的目标。...如果变量的值非空(在Makefile中,没有定义的变量的值为空),表达式为真。...Makefile函数 GNU make 提供了大量的函数用来处理文件名、变量、文本和命令。通过这些函数,用户可以节省很多精力,编写出更加灵活和健壮的Makefile。...通配符 在Makefile中表示一个文件名时,可以使用通配符。...:所有更新过的依赖文件 在Makefile中,通配符主要用在两个场合: 用在规则的目标和依赖中:make在读取Makefile时会自动对其进行匹配处理 test: *.o gcc -o $@ $
make程序需要一个编译规则说明文件,称为makefile,makefile文件中描述了整个软件工程的编译规则和各个文件之间的依赖关系。...makefile就像是一个shell脚本一样,其中可以执行操作系统的命令,它带来的好处就是我们能够实现“自动化编译”,一旦写好,只要一个make命令,整个软件功能就完全自动编译,提高了软件开发的效率。...make是一个命令工具,是一个解释makefile中指令的命令工具,一般来说大多数编译器都有这个命令,使用make可以是重新编译的次数达到最小化。...makefile文件的规则可以非常复杂,比C程序还要复杂,平常使用实际用不了那么多 接下来,介绍它的使用方法: ?...该文件夹下含有很多个c文件,如果我们想要每个c文件生成对应的可执行文件,则需要在控制台敲编译命令很多次,而且每次重新编译都需要重新敲命令 第一种方法:在该文件夹下创建makefile文件,内容如下: #
这就是makefile的规则。也就是makefile中最核心的内容。 说到底,makefile的东西就是这样一点,好像我的这篇文档也该结束了。呵呵。...edit : main.o kbd.o command.o display.o \ insert.o search.o files.o utils.o /*注释:如果后面这些.o文件比edit...上面就是一个makefile的概貌,也是makefile的基础,下面还有很多makefile的相关细节,准备好了吗?准备好了就来。 Makefile里有什么?...Makefile里主要包含了五个东西:显式规则、隐晦规则、变量定义、文件指示和注释。 显式规则。显式规则说明了,如何生成一个或多个目标文件。...注释。Makefile中只有行注释,和UNIX的Shell脚本一样,其注释是用“#”字符,这个就像C/C++中的“//”一样。
SOURCES = $(wildcard ./src/*.c) #把指定目录./src/所有后缀是c的文件展开
领取专属 10元无门槛券
手把手带您无忧上云