`
甜甜的眼泪
  • 浏览: 16293 次
  • 性别: Icon_minigender_2
社区版块
存档分类
最新评论

深入探究死锁的三种处理方法

阅读更多

              死锁的处理方法我们以火灾为例。要想火灾处理有三种办法,(1)提前预防,使环境没有火灾产生的环境,如降低周边温度,周边没有氧气等等(2)当出现火灾时,我们及时救火。(3)如果火灾离消防队比较远,等消防队过去火,就烧完了,我们可以自动放弃不管他。

       类似火灾死锁的三种处理方法 死锁预防;死锁避免;鸵鸟政策。

 死锁预防

      死锁出现有4个必要条件。只要确保一个必要条件不成立,就能预防死锁发生。下面我们分别讨论下每个条件不成立的情况。

        互斥 对于非共享资源必须要有互斥条件。如打印机不能同时为多个进程所共享。而对于共享的资源不要求互斥访问,因此不会出现死锁。如只读文件,多个程序同时打开只读文件。因此通过否定互斥来避免死锁是不太现实的。      占有并等待 为了确保占有并等待不在系统内出现,必须保证:当一个进程申请一个资源时,他不能占有其他资源

(1)执行前一次性请求所有的资源(不一定实现);

(2)即申请资源前先释放所有的资源。

这两种协议主要有两个缺点 第一 资源利用率可能比较低。

                         第二 可能会发生饥饿。

因此想要消除是不可能的。

        非抢占  为了确保这一条件不成立,可以使用如下协议:如果一个进程占有资源并申请另一个不能立即分配的资源,那么其已分配的资源可能被抢占。换句话说也就是被隐式释放了。抢占资源分配到进程所等待的资源的链表上。只有进程获得原有资源和所申请的新资源时。进程才可以重新执行。这个协议通常应用于状态可以保存和恢复的资源,如CPU寄存器和内存。他一般不适用于其他资源如打印机和磁带驱动器。

        循环等待  一个确保此条件不成立的方法就是对所有的资源类型进行完全排序,并要求每个进程按递增顺序来申请资源。

死锁避免——银行家算法

    死锁预防:确保四个必要条件其中之一不会发生的副作用是降低设备的使用率和系统吞吐率。

    思索避免的另一种方法是,获得之后如何申请资源的附加信息。根据这种方法,有不同的算法。死锁避免算法动态的检测资源分配状态以确保循环等待条件不可能成立。资源分配状态可能由可用资源和已分配资源,及进程最大需求所决定。下面我们研究两种死锁避免算法。

    资源分配图算法  资源分配图可修改以用于死锁避免。

    银行家算法 对于每种资源类型有多个实例的的资源分配系统,资源分配图的算法就不再适用了,那么这种情况我们就使用银行家算法。但银行家算法的的效率比资源分配图低。因为银行家算法可用于银行系统,所以叫银行家算法。

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

      

 

 

分享到:
评论

相关推荐

    并发访问ORACLE数据库的数据死锁分析和解决措施.pdf

    本文将深入探讨并发访问Oracle数据库时数据死锁的原因,并提出有效的分析和解决措施,以期为相关技术人员提供专业指导和参考文献。 首先,要理解数据死锁的概念。在关系型数据库的多个事务中,若每个事务都在等待...

    waveOut测试资源

    另一种方法是重新设计程序的架构,避免长时间持有资源,或者确保所有的资源获取顺序是一致的,从而防止死锁的经典条件:循环等待。 压缩包内的`testWave`文件可能是作者用来测试`waveOut`功能的代码或数据文件。...

    深入编程内幕

    深入学习编程内幕,意味着我们要探究这些概念的底层实现和优化技巧。 在VC++环境中,我们可以通过MFC(Microsoft Foundation Classes)库来简化Windows应用的开发。MFC是对Windows API的一层抽象,提供了一套面向...

    informix深入编程快速编程指南.rar

    总的来说,《Informix 深入编程快速编程指南》是一本全面的参考资料,不仅适合初学者了解Informix的基础知识,也适合有经验的开发者深入探究Informix的高级特性,从而提升其在数据库编程领域的专业技能。通过深入...

    深入理解Linux内核

    《深入理解Linux内核》是一本深受欢迎的Linux内核解析书籍,对于想要探究Linux操作系统核心奥秘的读者来说,是一本不可多得的指南。该书第三版于2005年出版,作者通过清晰易懂的方式,揭示了Linux内核的工作原理和...

    操作系统银行家算法的实现报告

    2. **掌握死锁机制**:探究死锁产生的根本原因、产生的必要条件以及处理死锁的基本方法。 3. **预防死锁策略**:掌握预防死锁的有效方法,并理解系统安全状态的概念。 4. **银行家算法实践**:重点介绍银行家算法的...

    java面试题_总结(3题)

    在实际面试中,面试官可能会深入探究每个话题的细节,包括但不限于内存模型的深入理解、垃圾收集器的优化策略、线程同步的高级技巧以及异常处理的最佳实践。掌握这些知识点对于成为一名优秀的Java开发者至关重要。...

    经典书籍--深入理解计算机

    当我们深入探讨计算机系统时,我们不仅在探究一个复杂的机械装置,而是一个充满无限可能的数字世界。《深入理解计算机》这本书,不仅仅是对计算机运行机制的描述,更是为那些希望在编程这条道路上走得更远的专业人士...

    操作系统试验报告

    通过这三个实验,学生不仅能够理论联系实际,深入理解操作系统中关键组件的运作机制,还能培养编程能力,特别是在处理机调度、资源分配和存储管理方面的技能,这对于IT行业的实践者而言至关重要。实验设计不仅强调了...

    轮转调度算法操作系统实验报告.pdf

    在本实验中,我们将深入探究时间片轮转调度算法的原理和实现。 二、时间片轮转调度算法原理 时间片轮转调度算法是一种常见的调度算法,该算法将系统的处理机资源分配给每个进程,以便实现公平的资源分配。该算法的...

    实验5-操作系统进程与文件管理--实验报告表-&--作业-5.doc

    通过这次实验,对进程的运行机制和死锁有了更深入的理解,认识到资源分配和同步的重要性。在遇到不理解的问题时,通过反复学习和与同学交流,成功地解决了疑惑。这不仅加深了对操作系统的认识,也锻炼了解决问题的...

    深入理解JVM内存结构及运行原理全套视频加资料.txt

     第58讲 死锁原理以及可视化虚拟机工具-Jconsole线程死锁监控 00:10:38  第59讲 VisualVM使用详解 00:08:03  第60讲 性能调优概述 00:11:22  第61讲 性能调优-案例1 00:23:28  第62讲 性能调优-案例2 00:...

    07.9三级数据库

    10. 多维分析:在数据分析和数据仓库中,多维分析(OLAP)用于从不同角度对数据进行深入探究,如切片、切块、钻取和旋转操作。 三级数据库技术的学习和考试涉及的内容广泛,要求考生具备扎实的理论基础和实践经验。...

    操作系统学习笔记详解:基础知识与核心技术

    文章不仅介绍了操作系统的启动阶段,从加电、BIOS、GRUB启动直至内核加载、执行init等具体过程,同时也深入探讨了中断和服务处理、进程间的邮件通信、线程与死锁的概念及其预防解决机制。此外,本文还包括对进程控制...

    操作系统原理课后答案

    《操作系统原理》第四版的课后答案,为学习者提供了一个自我检验和提升的平台,帮助他们深入探究操作系统原理,提升问题解决能力,为未来在软件开发、系统管理或相关领域的职业发展打下坚实基础。无论是对初学者还是...

    操作系统实验指导书--计算机专业.pdf

    实验要求学生通过设计资源分配系统,掌握内存和CPU时间的动态分配,并且学会运用银行家算法等方法来预防死锁现象的出现。在此过程中,学生不仅要解决资源竞争的问题,还需学会分析系统的资源分配效率,从而更深入地...

    基于单片机的超声波测距电路的研究.doc

    【超声波测距技术与AVR单片机应用】 超声波测距技术是一种非接触式的测距方法,广泛应用于各种领域,如自动化设备、...通过对这一系统的深入探究,不仅可以提升硬件设计能力,也能促进对嵌入式系统开发的全面理解。

    jvm理解pdf

    《深入理解Java虚拟机:JVM高级特性与最佳实践》这本书是Java开发者深入探究JVM(Java Virtual Machine)的重要参考资料。JVM作为Java程序运行的基础,它的理解和优化对于提升Java应用性能至关重要。以下将详细阐述...

    C#开发技术大全(书)pdf

    综上所述,《C#开发技术大全》这本书将引导读者深入探究C#语言的各个方面,从基本概念到高级特性,从单线程编程到多线程并发,从简单的数据操作到复杂的查询技术,全面覆盖了一个C#开发者所需的知识点。通过学习这些...

Global site tag (gtag.js) - Google Analytics