ImageVerifierCode 换一换
格式:PDF , 页数:9 ,大小:505.57KB ,
资源ID:3327452      下载积分:2 积分
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝扫码支付 微信扫码支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.wnwk.com/docdown/3327452.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(2.4_1_死锁的概念.pdf)为本站会员(a****2)主动上传,蜗牛文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知蜗牛文库(发送邮件至admin@wnwk.com或直接QQ联系客服),我们立即给予删除!

2.4_1_死锁的概念.pdf

1、本节内容死锁的概念王道考研/CSKAOYAN.COM王道考研/CSKAOYAN.COM知识总览知识总览王道考研/CSKAOYAN.COM什么是死锁什么是死锁哲学家进餐问题中,如果5位哲学家进程并发执行,都拿起了左手边的筷子0011223344semaphorechopstick5=1,1,1,1,1;Pi()/i号哲学家的进程while(1)P(chopsticki);/拿左P(chopstick(i+1)%5);/拿右吃饭V(chopsticki);/放左V(chopstick(i+1)%5);/放右思考每位哲学家都在等待自己右边的人放下筷子,这些哲学家进程都因等待筷子资源而被阻塞。即发生“

2、死锁”王道考研/CSKAOYAN.COM什么是死锁什么是死锁有一首歌的歌词:我爱你,你爱他,他爱她,她爱我这世界每个人都爱别人我们从资源占有的角度来分析,这段关系为什么看起来那么纠结我你他她我你他她我占有她的心,在等待你的心他占有你的心,在等待她的心你占有我的心,在等待他的心她占有他的心,在等待我的心每个人都占有一个资源,同时又在等待另一个人手里的资源。发生“死锁”在并发环境下,各进程因竞争资源而造成的一种互相互相等等待对方手里的资源,导致各待对方手里的资源,导致各进程都阻塞进程都阻塞,都无法,都无法向前推向前推进进的现象,就是“死锁”。发生死锁后若无外力干涉,这些进程都将无法向前推进。王道考

3、研/CSKAOYAN.COM死锁、饥饿、死循环的区别死锁、饥饿、死循环的区别死锁:各进程互相等待对方手里的资源,导致各进程都阻塞,无法向前推进的现象。饥饿:由于长期得不到想要的资源,某进程无法向前推进的现象。比如:在短进程优先(SPF)算法中,若有源源不断的短进程到来,则长进程将一直得不到处理机,从而发生长进程“饥饿”。死循环:某进程执行过程中一直跳不出某个循环的现象。有时是因为程序逻辑 bug 导致的,有时是程序员故意设计的。共同点共同点区别区别死锁都是进程无法顺利向前推进的现象(故意设计的死循环除外)死锁一定是“循环等待对方手里的资源”导致的,因此如果有死锁现象,那至少有两个或两个以上的进

4、程同时发生死锁。另外,发生死锁的进程一定处于阻塞态。饥饿可能只有一个进程发生饥饿。发生饥饿的进程既可能是阻塞态(如长期得不到需要的I/O设备),也可能是就绪态(长期得不到处理机)死循环可能只有一个进程发生死循环。死循环的进程可以上处理机运行(可以是运行态),只不过无法像期待的那样顺利推进。死锁和饥饿问题是由于操作系统分配资源的策略不合理导致的,而死循环是由代码逻辑的错误导致的。死锁和饥饿是管理者(操作系统)的问题,死循环是被管理者的问题。王道考研/CSKAOYAN.COM死锁产生的必要条件死锁产生的必要条件产生死锁必须同时满足一下四个条件,只要其中任一条件不成立,死锁就不会发生。互斥条件:只有

5、对必须互斥使用的资源的争抢才会导致死锁(如哲学家的筷子、打印机设备)。像内存、扬声器这样可以同时让多个进程使用的资源是不会导致死锁的(因为进程不用阻塞等待这种资源)。0011223344不剥夺条件:进程所获得的资源在未使用完之前,不能由其他进程强行夺走,只能主动释放。请求和保持条件:进程已经保持了至少一个资源,但又提出了新的资源请求,而该资源又被其他进程占有,此时请求进程被阻塞,但又对自己已有的资源保持不放。循环等待条件:存在一种进程资源的循环等待链,链中的每一个进程已获得的资源同时被下一个进程所请求。注意!发生死锁时一定有循环等待,但是发生循环等待时未必死锁(循环等待是死锁的必要不充分条件)

6、如果同类资源数大于1,则即使有循环等待,也未必发生死锁。但如果系统中每类资源都只有一个,那循环等待就是死锁的充分必要条件了。王道考研/CSKAOYAN.COM什么时候会发生死锁什么时候会发生死锁1.对系统资源的竞争。各进程对不可剥夺的资源(如打印机)的竞争可能引起死锁,对可剥夺的资源(CPU)的竞争是不会引起死锁的。2.进程推进顺序非法。请求和释放资源的顺序不当,也同样会导致死锁。例如,并发执行的进程P1、P2 分别申请并占有了资源 R1、R2,之后进程P1又紧接着申请资源R2,而进程P2又申请资源R1,两者会因为申请的资源被对方占有而阻塞,从而发生死锁。3.信号量的使用不当也会造成死锁。如生产者-消费者问题中,如果实现互斥的P操作在实现同步的P操作之前,就有可能导致死锁。(可以把互斥信号量、同步信号量也看做是一种抽象的系统资源)总之,对不可剥夺资源的不合理分配,可能导致死锁。王道考研/CSKAOYAN.COM死锁的处理策略死锁的处理策略1.预防死锁。破坏死锁产生的四个必要条件中的一个或几个。2.避免死锁。用某种方法防止系统进入不安全状态,从而避免死锁(银行家算法)3.死锁的检测和解除。允许死锁的发生,不过操作系统会负责检测出死锁的发生,然后采取某种措施解除死锁。王道考研/CSKAOYAN.COM知识回顾与重要考点知识回顾与重要考点

copyright@ 2008-2023 wnwk.com网站版权所有

经营许可证编号:浙ICP备2024059924号-2