操作系统之死锁
2015-10-13 21:08
197 查看
死锁是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种相互等待的现象若无外力作用,他们都将无法推进下去。此时系统处于死锁状态或系统产生了死锁。
产生死锁的四个必要条件:
(1)互斥条件:一个资源每次只能被一个进程使用;
(2)请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放;
(3)不剥夺条件:进程已获得的资源,在未使用完之前,不能强行剥夺;
(4)循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。
这四个是死锁的必要条件,只要系统发生了死锁,这些条件必然成立,而只要上述条件之一不满足,就不会发生死锁。
根据产生死锁的四个必要条件,只要使其中之一不能成立,死锁就不会出现。为此,可以采取下列三种预防措施:
(1)采用资源静态分配策略,破坏“部分分配”条件;
(2)允许进程剥夺使用其他进程占用的资源,从而破坏“不可剥夺”条件;
(3)采用资源有序分配法,破坏“环路”条件。
产生死锁的四个必要条件:
(1)互斥条件:一个资源每次只能被一个进程使用;
(2)请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放;
(3)不剥夺条件:进程已获得的资源,在未使用完之前,不能强行剥夺;
(4)循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系。
这四个是死锁的必要条件,只要系统发生了死锁,这些条件必然成立,而只要上述条件之一不满足,就不会发生死锁。
根据产生死锁的四个必要条件,只要使其中之一不能成立,死锁就不会出现。为此,可以采取下列三种预防措施:
(1)采用资源静态分配策略,破坏“部分分配”条件;
(2)允许进程剥夺使用其他进程占用的资源,从而破坏“不可剥夺”条件;
(3)采用资源有序分配法,破坏“环路”条件。
相关文章推荐
- 应用领航:盘点那些年我们一起追过的OS
- 无奇不有!盘点各国自己开发的操作系统
- 可自定义oem的萝卜家园 Ghost XP 新春装机版 V200801 下载
- C#实现判断操作系统是否为Win8以上版本
- Linux操作系统添加新硬盘方法
- java如何获取本地操作系统进程列表
- Linux rdesktop操作系统下远程登录Windows XP桌面
- 32位操作系统认出超出4G内存的方法
- Linux rpm tar 操作系统下软件的安装与卸载方法
- JavaScript 获取用户客户端操作系统版本
- jsp 获取客户端的浏览器和操作系统信息
- Windows 操作系统的安全设置
- PHP获取用户的浏览器与操作系统信息的代码
- Perl操作系统环境变量的脚本代码
- javascript获取本机操作系统类型的方法
- 封装好的js判断操作系统与浏览器代码分享
- javascript实现获取浏览器版本、操作系统类型
- php根据操作系统转换文件名大小写的方法
- JS获得浏览器版本和操作系统版本的例子
- Python中使用异常处理来判断运行的操作系统平台方法