【Linux】基础开发工具(4):自动化构建--make/makefile

前文回顾:【Linux】基础开发工具(3):编译器


目录

[一 自动化工程构建----make/makefile](#一 自动化工程构建----make/makefile)

[1 背景](#1 背景)

[2 见一下怎么用](#2 见一下怎么用)

[3 理解Makefile/make,编译工作的推导过程,依赖关系和依赖方法](#3 理解Makefile/make,编译工作的推导过程,依赖关系和依赖方法)

[4 makefile最佳实践和实用语法](#4 makefile最佳实践和实用语法)


一 自动化工程构建----make/makefile

1 背景

· 会不会写 makefile,从一个侧面说明了一个人是否具备完成大型工程的能力

・一个工程中的源文件不计其数,其按类型、功能、模块分别放在若干个目录中,makefile 定义了一系列的规则来指定,哪些文件需要先编译,哪些文件需要后编译,哪些文件需要重新编译,甚至于进行更复杂的功能操作

makefile 带来的好处就是 ------"自动化编译",一旦写好,只需要一个 make 命令,整个工程完全自动编译,极大的提高了软件开发的效率。

make 是一个命令工具,是一个解释 makefile 中指令的命令工具,一般来说,大多数的 IDE 都有这个命令,比如:Delphi 的 make,Visual C++ 的 nmake,Linux 下 GNU 的 make。可见,makefile 都成为了一种在工程方面的编译方法

・make 是一条命令,makefile 是一个文件,两个搭配使用,完成项目自动化构建

make:一个命令

makefile/Makefile:文件--->描述的是如何翻译当前工程

2 见一下怎么用

3 理解Makefile/make,编译工作的推导过程,依赖关系和依赖方法

Makefile/make是依赖关系和依赖方法的集合

目标code依赖于源文件code.c,执行make命令时会自动调用gcc -o code code.c命令,将code.c编译为可执行文件code

**思考:**为什么执行code:code.c时,make后面没有跟东西,而执行clean时要写make clean?如果将上面代码的顺序换一下呢?

make/makefile:具体如何形成可执行程序的呢??推导的过程

make从上到下遇到的第一个文件,把对应的指令入栈,依次遍历,直到遍历结束,之后开始出栈,直到栈为空。当程序执行函数调用时,会将当前指令的下一条地址(返回地址)压入栈,函数执行完毕后,从栈中弹出该地址,回到原来的执行位置。

make如何知道code.c是否需要被重新编译?

清理工程

makefile使用#注释,vim用单引号注释

源文件与目标文件的 Modify 时间对比逻辑:

C 程序编译前后的文件状态对比:

4 makefile最佳实践和实用语法

malidfile最佳实践:

编译器将多个 C 源文件(如add.c、sub.c)转换为目标文件(.o文件,如add.o、sub.o),之后链接器将目标文件与库文件结合,生成可执行程序。

@(代表当前规则的 "目标",即code.exe)、^(代表当前规则的 "所有依赖",即code.o)

Makefile 变量定义:统一管理构建路径

makefile批量化处理:

做法一:

做法二:

相关推荐
Trouvaille ~3 小时前
【Linux】UDP Socket编程实战(三):多线程聊天室与线程安全
linux·服务器·网络·c++·安全·udp·socket
江湖有缘4 小时前
Docker环境下使用RustScan端口扫描工具教程
运维·docker·容器
海棠AI实验室4 小时前
VS Code Remote-SSH :原理、前置条件、配置套路与踩坑清单
运维·ssh
梦想的旅途24 小时前
Java/Python/Go 实现企微外部群自动化消息推送
运维·自动化·企业微信
赋创小助手4 小时前
NVIDIA B200 GPU 技术解读:Blackwell 架构带来了哪些真实变化?
运维·服务器·人工智能·深度学习·计算机视觉·自然语言处理·架构
sagima_sdu4 小时前
bin、sbin 与 usr/bin、usr/sbin 目录的区别和由来
linux·运维·网络
前进的程序员4 小时前
驱动开发中Linux系统裁剪、开发、调试步骤
linux·驱动开发·设备树
70asunflower4 小时前
镜像仓库(Image Registries)详解
linux·docker·容器
Monly214 小时前
Linux:分包上传文件
linux
岁岁种桃花儿4 小时前
深度解析DolphinScheduler核心架构:搭建高可用Zookeeper集群
linux·分布式·zookeeper