# 死锁,第 1 部分:资源分配图
> 原文:<https://github.com/angrave/SystemProgramming/wiki/Deadlock%2C-Part-1%3A-Resource-Allocation-Graph>
## 什么是资源分配图?
资源分配图跟踪哪个进程持有哪个资源以及哪个进程正在等待特定类型的资源。它是一个非常强大而简单的工具,用于说明交互过程如何解锁。如果进程是 _ 使用 _ 资源,则从资源节点向进程节点绘制箭头。如果进程是 _ 请求 _ 资源,则从进程节点向资源节点绘制箭头。
如果资源分配图中存在循环,并且循环中的每个资源仅提供一个实例,则进程将死锁。例如,如果进程 1 保存资源 A,则进程 2 保存资源 B,进程 1 等待 B,进程 2 等待 A,然后进程 1 和进程 2 将被死锁。
这是另一个示例,显示进程 1 和 2 获取资源 1 和 2,而进程 3 正在等待获取两个资源。在这个例子中没有死锁,因为没有循环依赖。
![ResourceAllocationGraph-Ex1.png](https://img.kancloud.cn/9e/0b/9e0bdd3936b36f6988dfc43707396721_1175x913.jpg)
## 僵局!
很多时候,我们不知道可以获取资源的具体顺序,因此我们可以绘制图表。
![](https://img.kancloud.cn/ca/81/ca8147c0878d8f069a1877026085a1e3_463x243.jpg)
作为一种可能性矩阵。然后我们可以绘制箭头,看看是否有导致我们陷入僵局的定向版本。
![RAG Deadlock](https://img.kancloud.cn/83/0c/830ce4f5be278b6ec9973913d17f4f66_463x243.jpg)
请考虑以下资源分配图(假设进程要求对文件进行独占访问)。如果你有一堆进程正在运行并且它们请求资源并且操作系统最终处于这种状态,那么你就会陷入僵局!您可能看不到这一点,因为操作系统可能* _ 抢占 _ 某些进程打破了循环,但仍有一个变化,您的三个孤独进程可能会死锁。您还可以使用`make`和规则依赖关系(例如我们的 parmake MP)制作这些图形。
![](https://img.kancloud.cn/6e/05/6e0596ad2cf75369fb24073cd99900ba.svg)
- UIUC CS241 系统编程中文讲义
- 0. 简介
- #Informal 词汇表
- #Piazza:何时以及如何寻求帮助
- 编程技巧,第 1 部分
- 系统编程短篇小说和歌曲
- 1.学习 C
- C 编程,第 1 部分:简介
- C 编程,第 2 部分:文本输入和输出
- C 编程,第 3 部分:常见问题
- C 编程,第 4 部分:字符串和结构
- C 编程,第 5 部分:调试
- C 编程,复习题
- 2.进程
- 进程,第 1 部分:简介
- 分叉,第 1 部分:简介
- 分叉,第 2 部分:Fork,Exec,等等
- 进程控制,第 1 部分:使用信号等待宏
- 进程复习题
- 3.内存和分配器
- 内存,第 1 部分:堆内存简介
- 内存,第 2 部分:实现内存分配器
- 内存,第 3 部分:粉碎堆栈示例
- 内存复习题
- 4.介绍 Pthreads
- Pthreads,第 1 部分:简介
- Pthreads,第 2 部分:实践中的用法
- Pthreads,第 3 部分:并行问题(奖金)
- Pthread 复习题
- 5.同步
- 同步,第 1 部分:互斥锁
- 同步,第 2 部分:计算信号量
- 同步,第 3 部分:使用互斥锁和信号量
- 同步,第 4 部分:临界区问题
- 同步,第 5 部分:条件变量
- 同步,第 6 部分:实现障碍
- 同步,第 7 部分:读者编写器问题
- 同步,第 8 部分:环形缓冲区示例
- 同步复习题
- 6.死锁
- 死锁,第 1 部分:资源分配图
- 死锁,第 2 部分:死锁条件
- 死锁,第 3 部分:餐饮哲学家
- 死锁复习题
- 7.进程间通信&amp;调度
- 虚拟内存,第 1 部分:虚拟内存简介
- 管道,第 1 部分:管道介绍
- 管道,第 2 部分:管道编程秘密
- 文件,第 1 部分:使用文件
- 调度,第 1 部分:调度过程
- 调度,第 2 部分:调度过程:算法
- IPC 复习题
- 8.网络
- POSIX,第 1 部分:错误处理
- 网络,第 1 部分:简介
- 网络,第 2 部分:使用 getaddrinfo
- 网络,第 3 部分:构建一个简单的 TCP 客户端
- 网络,第 4 部分:构建一个简单的 TCP 服务器
- 网络,第 5 部分:关闭端口,重用端口和其他技巧
- 网络,第 6 部分:创建 UDP 服务器
- 网络,第 7 部分:非阻塞 I O,select()和 epoll
- RPC,第 1 部分:远程过程调用简介
- 网络复习题
- 9.文件系统
- 文件系统,第 1 部分:简介
- 文件系统,第 2 部分:文件是 inode(其他一切只是数据...)
- 文件系统,第 3 部分:权限
- 文件系统,第 4 部分:使用目录
- 文件系统,第 5 部分:虚拟文件系统
- 文件系统,第 6 部分:内存映射文件和共享内存
- 文件系统,第 7 部分:可扩展且可靠的文件系统
- 文件系统,第 8 部分:从 Android 设备中删除预装的恶意软件
- 文件系统,第 9 部分:磁盘块示例
- 文件系统复习题
- 10.信号
- 过程控制,第 1 部分:使用信号等待宏
- 信号,第 2 部分:待处理的信号和信号掩码
- 信号,第 3 部分:提高信号
- 信号,第 4 部分:信号
- 信号复习题
- 考试练习题
- 考试主题
- C 编程:复习题
- 多线程编程:复习题
- 同步概念:复习题
- 记忆:复习题
- 管道:复习题
- 文件系统:复习题
- 网络:复习题
- 信号:复习题
- 系统编程笑话