Makefile 基础与常用语法详解

2024-08-30 17:36

本文主要是介绍Makefile 基础与常用语法详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

6889d63637ca4456a60f7f37c0ff5b1d.png

目录

 

一、引言

二、Makefile 基础概念

1.目标、依赖和命令

2.文件名和搜索路径

3.执行顺序和依赖关系

三、Makefile 常用语法

1.变量和宏定义

2.自动变量

3.模式规则 

4.条件判断

5.循环

6.伪目标

 

四、Makefile 实际应用示例

五、总结


 

一、引言

        在软件开发过程中,项目的构建和管理是至关重要的环节。Makefile 作为一种强大的工具,能够自动化地完成项目的编译、链接和部署等任务,极大地提高了开发效率。本文将深入介绍 Makefile 的基础概念和常用语法,帮助读者更好地掌握这一工具。

 

二、Makefile 基础概念

1.目标、依赖和命令

Makefile 由目标(target)、依赖(dependency)和命令(command)组成。目标通常是一个文件或一个动作,依赖是生成目标所需要的文件或其他目标,命令是用于生成目标的具体操作。

例如:

myprogram: main.o func.ogcc main.o func.o -o myprogram

在这个例子中,myprogram是目标,main.ofunc.o是依赖,gcc main.o func.o -o myprogram是命令。这个规则表示如果main.ofunc.o文件发生了变化,就执行gcc命令来生成可执行文件myprogram

 

2.文件名和搜索路径

  • Makefile 通常以文件名 “Makefile” 或 “makefile” 命名。在执行make命令时,Make 工具会自动查找当前目录下的 Makefile 文件,并按照其中的规则进行构建。
  • 如果你的项目比较复杂,可以将 Makefile 拆分为多个文件,然后使用include指令将它们包含进来。Make 工具会按照指定的搜索路径查找被包含的 Makefile 文件。

 

3.执行顺序和依赖关系

  • Makefile 中的规则是按照依赖关系和目标的先后顺序执行的。如果一个目标的依赖发生了变化,Make 工具会自动重新执行生成该目标的命令。
  • 例如,如果main.c文件发生了变化,Make 工具会重新编译main.c生成main.o,然后再重新链接生成myprogram

 

三、Makefile 常用语法

1.变量和宏定义

  • Makefile 支持变量和宏定义,可以将常用的路径、文件名或命令等定义为变量,以便在不同的规则中重复使用。
  • 变量定义可以使用 “=”、“:=” 或 “define” 等方式。例如:
CC = gcc
CFLAGS = -Wall -gmyprogram: main.o func.o$(CC) $(CFLAGS) main.o func.o -o myprogram

在这个例子中,定义了两个变量CCCFLAGS,分别表示编译器和编译选项。在规则中使用$(CC)$(CFLAGS)来引用这些变量。

 

2.自动变量

Makefile 提供了一些自动变量,如$@表示目标文件名,$<表示第一个依赖文件名,$^表示所有依赖文件名。

例如:

myprogram: main.o func.ogcc $^ -o $@

在这个例子中,$@表示目标文件名myprogram$^表示所有依赖文件名main.o func.o

其它自动变量如下图所示:

a019e09bd4994ed280116c4794741360.png

 

3.模式规则 

模式规则是一种通用的规则,可以用于构建多个具有相似名称和依赖关系的目标。它使用模式符号(%)来表示目标和依赖中的可变部分。

例如,以下是一个简单的模式规则:

%.o: %.cgcc -c $< -o $@

这个规则表示,对于任何以.c结尾的文件,都可以使用gcc -c命令将其编译为对应的以.o结尾的目标文件。

模式符号(%)在目标和依赖中表示可变部分。在上面的例子中,%.o表示任何以.o结尾的目标文件,%.c表示对应的以.c结尾的源文件。

当 Make 工具解析模式规则时,它会将目标和依赖中的模式符号替换为具体的文件名,以确定要构建的目标和依赖关系。

 

4.条件判断

Makefile 支持条件判断,可以根据不同的条件执行不同的命令。条件判断可以使用ifeqifneqifdefifndef等指令。

例如:

ifeq ($(DEBUG),1)CFLAGS += -DDEBUG
endifmyprogram: main.o func.ogcc $(CFLAGS) main.o func.o -o myprogram

在这个例子中,如果定义了变量DEBUG并且其值为 “1”,则在编译选项中添加-DDEBUG宏定义。 

 

5.循环

Makefile 支持循环,可以对一系列的文件或变量进行操作。循环可以使用foreachfor等指令。

例如:

SRCS = main.c func.c
OBJS = $(foreach src,$(SRCS),$(src:.c=.o))myprogram: $(OBJS)gcc $^ -o $@

在这个例子中,使用foreach指令将SRCS列表中的每个.c文件转换为.o文件,并将结果存储在OBJS变量中。

 

6.伪目标

伪目标不是一个真正的文件,而是一个动作的名称。可以使用.PHONY关键字来定义伪目标,以避免与同名的文件冲突。

例如:

.PHONY: clean allclean:rm -f *.o myprogramall: myprogram

在这个例子中,cleanall都是伪目标。执行make clean会删除所有的.o文件和可执行文件,执行make all会构建可执行文件。

 

四、Makefile 实际应用示例

假设我们有一个简单的 C 项目,包含main.cfunc.c两个文件。以下是一个 Makefile 的示例:

CC = gcc
CFLAGS = -Wall -gmyprogram: main.o func.ogcc main.o func.o -o myprogrammain.o: main.cgcc -c main.cfunc.o: func.cgcc -c func.cclean:rm -f *.o myprogram

在这个例子中,定义了一个可执行文件myprogram,它依赖于main.ofunc.o两个目标文件。分别为main.cfunc.c定义了编译规则,生成对应的.o文件。同时,定义了一个伪目标clean,用于删除生成的目标文件和可执行文件。

 

五、总结

        Makefile 是一个强大的工具,能够自动化地完成项目的构建和管理任务。通过掌握 Makefile 的基础概念和常用语法,你可以更加高效地进行软件开发。在实际应用中,可以根据项目的需求和特点,灵活地使用 Makefile 的各种功能,提高开发效率和代码质量。希望本文能够帮助读者更好地理解和使用 Makefile。

 

 

 

 

 

 

这篇关于Makefile 基础与常用语法详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1121483

相关文章

Linux换行符的使用方法详解

《Linux换行符的使用方法详解》本文介绍了Linux中常用的换行符LF及其在文件中的表示,展示了如何使用sed命令替换换行符,并列举了与换行符处理相关的Linux命令,通过代码讲解的非常详细,需要的... 目录简介检测文件中的换行符使用 cat -A 查看换行符使用 od -c 检查字符换行符格式转换将

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使

Android中Dialog的使用详解

《Android中Dialog的使用详解》Dialog(对话框)是Android中常用的UI组件,用于临时显示重要信息或获取用户输入,本文给大家介绍Android中Dialog的使用,感兴趣的朋友一起... 目录android中Dialog的使用详解1. 基本Dialog类型1.1 AlertDialog(

C#数据结构之字符串(string)详解

《C#数据结构之字符串(string)详解》:本文主要介绍C#数据结构之字符串(string),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录转义字符序列字符串的创建字符串的声明null字符串与空字符串重复单字符字符串的构造字符串的属性和常用方法属性常用方法总结摘

Java中StopWatch的使用示例详解

《Java中StopWatch的使用示例详解》stopWatch是org.springframework.util包下的一个工具类,使用它可直观的输出代码执行耗时,以及执行时间百分比,这篇文章主要介绍... 目录stopWatch 是org.springframework.util 包下的一个工具类,使用它

Java进行文件格式校验的方案详解

《Java进行文件格式校验的方案详解》这篇文章主要为大家详细介绍了Java中进行文件格式校验的相关方案,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、背景异常现象原因排查用户的无心之过二、解决方案Magandroidic Number判断主流检测库对比Tika的使用区分zip

Java实现时间与字符串互相转换详解

《Java实现时间与字符串互相转换详解》这篇文章主要为大家详细介绍了Java中实现时间与字符串互相转换的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录一、日期格式化为字符串(一)使用预定义格式(二)自定义格式二、字符串解析为日期(一)解析ISO格式字符串(二)解析自定义

springboot security快速使用示例详解

《springbootsecurity快速使用示例详解》:本文主要介绍springbootsecurity快速使用示例,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝... 目录创www.chinasem.cn建spring boot项目生成脚手架配置依赖接口示例代码项目结构启用s

Python中随机休眠技术原理与应用详解

《Python中随机休眠技术原理与应用详解》在编程中,让程序暂停执行特定时间是常见需求,当需要引入不确定性时,随机休眠就成为关键技巧,下面我们就来看看Python中随机休眠技术的具体实现与应用吧... 目录引言一、实现原理与基础方法1.1 核心函数解析1.2 基础实现模板1.3 整数版实现二、典型应用场景2

一文详解SpringBoot响应压缩功能的配置与优化

《一文详解SpringBoot响应压缩功能的配置与优化》SpringBoot的响应压缩功能基于智能协商机制,需同时满足很多条件,本文主要为大家详细介绍了SpringBoot响应压缩功能的配置与优化,需... 目录一、核心工作机制1.1 自动协商触发条件1.2 压缩处理流程二、配置方案详解2.1 基础YAML