操作系统——死锁——银行家算法

2024-04-16 06:20

本文主要是介绍操作系统——死锁——银行家算法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

银行家算法的实现需要三个矩阵:

  1. Max矩阵:用于存储每个进程完成所需要的全部资源量
  2. Allocation矩阵:用于存储每个进程每个资源已分配的情况
  3. Need矩阵:存储每个进程还需要的各个资源数

如下以一个实例来说明银行家算法:

假设一组进程,有P1,P2,P3,P4四个进程,有A,B,C,D四种资源:

要求使用银行家算法找出能够避免死锁的资源分配序列(如果存在避免死锁的序列)。

需求如下:

Max
/ABCD
P10656
P20012
P31750
P42356

每一行分别表示对应的进程Pi的完成需要多少对应资源。

每个进程当前得到资源的情况如下:

Allocation
/ABCD
P10014
P20012
P31000
P41354

还没有被使用的资源量为:

Available:A:1,B:5,C:2,D:0。

在现在这个情况下,需要完成所有进程,需要的资源量Need的计算方式为Max-Allocation得到:

Need
/ABCD
P10642
P20

0

00
P30750
P41002

表示现在还需要这么多资源才能完成,现在开始对P1到P4尝试为其分配资源,检查是否会导致死锁:

一、方案1——如果将资源优先分配给P1:

  • Available:A:1,B:5,C:2,D:0
  • P1需要:A:0,B:6,C:4,D:2

不安全。

二、方案2——优先分配给P2:

  • Available:A:1,B:5,C:2,D:0
  • P2需要:A:0,B:0,C:0,D:0

能够满足,安全,

P2进程完成后释放资源C:1,D:2。

现在的可用资源:Available:A:1,B:5,C:3,D:2

对于剩下的三个进程,能满足条件的只有P4,则分配给P4完成进程,后P4释放资源A:1,B:3,C:5,D:4,可用资源更新为:Available:A:2,B:8,C:8,D:6

对于剩下两个进程,都能满足......完成....释放....

....重复过程....

最终得到两个序列P2,P4,P1,P3和序列P2,P4,P3,P1

三、方案三——优先分配给P3

重复上述过程。

四、方案四——优先分配给P4

重复上述过程。

最终能够得到几个不会导致死锁且能安全完成这几个进程的操作序列,这个过程即银行家算法。

这篇关于操作系统——死锁——银行家算法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/908006

相关文章

SQL Server数据库死锁处理超详细攻略

《SQLServer数据库死锁处理超详细攻略》SQLServer作为主流数据库管理系统,在高并发场景下可能面临死锁问题,影响系统性能和稳定性,这篇文章主要给大家介绍了关于SQLServer数据库死... 目录一、引言二、查询 Sqlserver 中造成死锁的 SPID三、用内置函数查询执行信息1. sp_w

Java死锁问题解决方案及示例详解

《Java死锁问题解决方案及示例详解》死锁是指两个或多个线程因争夺资源而相互等待,导致所有线程都无法继续执行的一种状态,本文给大家详细介绍了Java死锁问题解决方案详解及实践样例,需要的朋友可以参考下... 目录1、简述死锁的四个必要条件:2、死锁示例代码3、如何检测死锁?3.1 使用 jstack3.2

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

Mysql如何解决死锁问题

《Mysql如何解决死锁问题》:本文主要介绍Mysql如何解决死锁问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录【一】mysql中锁分类和加锁情况【1】按锁的粒度分类全局锁表级锁行级锁【2】按锁的模式分类【二】加锁方式的影响因素【三】Mysql的死锁情况【1

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

如何通过Golang的container/list实现LRU缓存算法

《如何通过Golang的container/list实现LRU缓存算法》文章介绍了Go语言中container/list包实现的双向链表,并探讨了如何使用链表实现LRU缓存,LRU缓存通过维护一个双向... 目录力扣:146. LRU 缓存主要结构 List 和 Element常用方法1. 初始化链表2.