银行家算法笔记

死锁

在了解银行家算法前,有必要了解一下死锁。因为银行家算法是用于避免死锁的。

什么是死锁?

死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或者由于彼此通信而造成的一种阻塞的现象,若无外力作用,它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。—— 来自百度百科

死锁的四个必要条件
  • 互斥条件:指进程对所分配到的资源进行排它性使用,即在一段时间内某资源只由一个进程占用。如果此时还有其它进程请求该资源,则请求者只能等待,直至占有该资源的进程释放。
  • 请求和保持条件:指进程已经保持了至少一个资源,但又提出了新的资源请求,而该资源又已被其它进程占有,此时请求进程阻塞,但又对自己已获得的其它资源保持不放。
  • 不剥夺资源:指进程已获得的资源,在未使用完之前,不能被剥夺,只能在使用完时由自己释放。
  • 环路等待条件:指在发生死锁时,必然存在一个进程——资源的环形链,即进程集合{P0,P1,P2,...,Pn}中的 P0 正在等待一个 P1 占用的资源;P1 正在等待 P2 占用的资源,......,Pn 正在等待已被 P0 占用的资源。
银行家算法背景简介

在银行中,客户申请贷款的数量是有限的,每个客户在第一次申请贷款时要声明完成该项目所需的最大资金量,在满足所有贷款要求时,客户应及时归还。银行家在客户申请的贷款数量不超过自己拥有的最大值时,都应尽量满足客户的需要。在这样描述中,银行家就好比操作系统,资金就是资源,客户就相当于要申请资源的进程。

系统安全状态和不安全状态

所谓安全状态,是指系统能按某种进程顺序(P1,P2,…,Pn)(称<P1,P2,…,Pn>序列为安全序列),来为每个进程 Pi 分配其所需资源,直至满足每个进程对资源的最大需求,使每个进程都可顺利地完成。如果系统无法找到这样一个安全序列,则称系统处于不安全状态。
虽然并非所有的不安全状态都必然会转为死锁状态,但当系统进入不安全状态后,便有可能进而进入死锁状态。反之,只要系统处于安全状态,系统便可避免进入死锁状态。因此,避免死锁的状态的实质在于:系统在进行资源分配是,如何使系统不进入不安全状态。

银行家算法的数据结构
  1. 可利用资源向量 Available。这是一个含有 m 个 元素的数组,其中每一个元素代表一类可利用的资源数目,其初始值是系统中所配置的该类全部可用资源的数目,其数值随该类资源分配和回收动态地改变。如果 Available[j] = K,则表示系统中现有 Rj 类资源 K 个。
  2. 最大需求矩阵 Max。这是一个 n X m 的矩阵,它定义了系统中 n 个进程中的每一个进程对 m 类资源的最大需求。如果 Max[i,j] = K ,则表示进程 i 需要 Rj 类资源的最大数目为 K。
  3. 分配矩阵 Allocation。这也是一个 n X m 的矩阵,它定义了系统中每一类资源当前已分配给每一进程的资源树。如果 Allocation[i,j] = K,则表示进程 i 当前已分得 Rj 类资源的数目为 K。
  4. 需求矩阵 Need。这也是一个 n X m 的矩阵,用以表示每一个进程尚需的各类资源数。如果 Need[i,j] = K,则表示进程 i 还需要 Rj 类资源 K 个,方能完成任务。

上述的三个矩阵间存在下列关系:
Need[i,j] = Max[i,j] - Allocation[i,j]

银行家算法

设 Requesti 是进程 Pi 的请求向量,如果 Requesti[j] = K,表示进程 Pi 需要 K 个 Rj 类型的资源。当 Pi 发出资源请求后,系统按下列步骤进行检查。
(1)如果 Requesti[j] ≤ Need[i,j],便转向步骤(2);否则认为出错,因为它所需要的资源数已超过它所宣布的最大值。
(2)如果 Requesti[j] ≤ Available[j],便转向步骤(3);否则,表示尚无足够资源,Pi 须等待。
(3)系统试探着把资源分配给进程 Pi,并修改下面数据结构中的数值。
Available[j] = Available[j] - Requesti[j];
Allocation[i,j] = Allocation[i,j] +Requesti[j];
Need[i,j] = Need[i,j] - Requesti[j];
(4)系统执行安全性算法,检查此次资源分配后系统是否处于安全状态。若安全,才正式将资源分配给进程 Pi,以完成本次分配。否则,将本次的试探分配作废,恢复原来的资源分配,让进程等待。

安全性算法

系统所执行的安全性算法可描述如下:
(1)设置两个向量:
a.工作向量 Work,它表示系统可提供给进程继续运行所需的各类资源项目,它含有 m 个元素,在执行安全性算法开始时,Work = Available。
b.Finish,它表示系统是否有足够的资源分配给进程,使之运行完成。开始时先做 Finish[i] = false;当有足够资源分配给进程时,再令 Finish[i] = true。
(2)从进程集合中找到一个能满足下述条件的进程:
a.Finish[i] = false。
b.Need[i,j] ≤ Work[j];若找到,执行步骤(3),否则,执行步骤(4)
(3)当进程 Pi获得资源后,可顺利执行,直至完成,并释放出分配给它的资源,故应执行:
Work[j] = Work[j] + Allocation[i,j];
Finish[i] = true;
go to step2;
(4)如果所有进程的 Finish[i] = true 都满足,则表示系统处于安全状态;否则,系统处于不安全状态。

最后说两句

这篇文章的出现是因为面试的时候忘了,说不出个所以然来,所以回来翻书,抄了一遍,理解更加深入了。弱鸡的自己还需更加努力,打牢基础,慢慢拓展。

参考资料

[1] 百度百科
[2] 汤小红等编著.计算机操作系统[M]. 西安 : 西安电子科技大学出版社 , 2007.5.

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,390评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,821评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,632评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,170评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,033评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,098评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,511评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,204评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,479评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,572评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,341评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,893评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,171评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,486评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,676评论 2 335

推荐阅读更多精彩内容

  • 系统安全状态的定义 1.安全状态 在避免死锁的方法中,允许进程动态地申请资源,但系统在进行资源分配之前,应先计算此...
    haifengmay阅读 3,672评论 1 8
  • 一.死锁的概念以及产生死锁的原因 1.死锁的定义 在多道程序系统中,由于多个进程的并发执行,改善了系统资源的利用率...
    Chasel_H阅读 1,066评论 0 4
  • 以下内容整理自互联网,仅用于个人学习http://huachao1001.github.io/article.ht...
    学不好语文的LJ码农阅读 1,930评论 0 2
  • 至夜,手机提示收到qq消息 “你是?”对方发来消息, “我是你曾经同学,先加好友ok?” 过会儿,界面显示‘你们已...
    菲我19阅读 388评论 0 0
  • 广州,简称惠,别称羊城、花城,是广东省省会、是国际性的大都市,被全球权威机构GaWC评为世界级的一线城市。...
    桉桉欧尼阅读 1,009评论 0 8