操作系统--死锁应对的有关问题(1)
2013-08-29 22:56
246 查看
1,计算机发生死锁的原因
死锁发生的原因就是对计算机资源的一种争夺而造成的一种现象。
2,对死锁的描述
线程在使用资源时,是通过如下顺序:
a,请求资源
b,使用资源
c,释放资源
在请求资源没有批准的时候,线程开始等待:一种是阻塞式等待,另一种是立即返回。执行别的任务。
立即返回时,线程是不会发生死锁的。只有在阻塞式等待时,发生死锁现象。
死锁正式定义:
如果有一组线程,每个线程都是在等待一个事件的发生,而这个事件只能由该租线程里面的另一个线程发出,
我们称这组线程发生了死锁。
3,死锁的4个必要的条件
①:死锁发生的必要条件是资源有限。
这是非常直观的现象,如果资源是无限的,大可不必等待别的线程释放资源后再去请求资源,和人类一样。
②:死锁的另一个必要的条件就是持有等待。
如果一个线程一直不释放资源,别人在请求资源时,总是等不到资源。造成死锁。
③:还有就是不可抢占。
如果一个线程能抢占别的线程的资源,别的线程的资源就会立即释放,不会造成持有等待。
④:循环等待条件。
也就是死循环。
4,死锁的应对
①:允许死锁的发生
一:可以当作没看见,不处理。
二:在死锁发生之后,才想办法处理。
②:不允许死锁的发生
一:考虑周全。
二:使用消除死锁的必要条件。
5,消除死锁的必要条件
①:消除资源独占条件
就是将有限资源增大到无限和共享资源。
将有限资源增大到无限,这个并不实际,也不需要。线程总是有限,所以对请求的资源也可限。
共享资源是可以实现的,比如共享的打印机。
②:消除保持和请求条件
就是一个进程一次性请求完所有的资源,不再请求一点资源后,再去执行一些任务。
这样做的缺点就是资源太过浪费,有些进程只有在最后的时候才请求所需的资源,如果一开始就占用,非常影响效率。
③:消除非抢占条件
就是运行进程对别的进程资源的抢占。这也是cpu和内存调度的一个关键。
缺点是,如果在抢占资源时,将一个死锁资源抢占过来,则后果很严重。
④:消除循环等待时间
就是我们设定请求资源的顺序,不再让进程随机无序的请求资源。
死锁发生的原因就是对计算机资源的一种争夺而造成的一种现象。
2,对死锁的描述
线程在使用资源时,是通过如下顺序:
a,请求资源
b,使用资源
c,释放资源
在请求资源没有批准的时候,线程开始等待:一种是阻塞式等待,另一种是立即返回。执行别的任务。
立即返回时,线程是不会发生死锁的。只有在阻塞式等待时,发生死锁现象。
死锁正式定义:
如果有一组线程,每个线程都是在等待一个事件的发生,而这个事件只能由该租线程里面的另一个线程发出,
我们称这组线程发生了死锁。
3,死锁的4个必要的条件
①:死锁发生的必要条件是资源有限。
这是非常直观的现象,如果资源是无限的,大可不必等待别的线程释放资源后再去请求资源,和人类一样。
②:死锁的另一个必要的条件就是持有等待。
如果一个线程一直不释放资源,别人在请求资源时,总是等不到资源。造成死锁。
③:还有就是不可抢占。
如果一个线程能抢占别的线程的资源,别的线程的资源就会立即释放,不会造成持有等待。
④:循环等待条件。
也就是死循环。
4,死锁的应对
①:允许死锁的发生
一:可以当作没看见,不处理。
二:在死锁发生之后,才想办法处理。
②:不允许死锁的发生
一:考虑周全。
二:使用消除死锁的必要条件。
5,消除死锁的必要条件
①:消除资源独占条件
就是将有限资源增大到无限和共享资源。
将有限资源增大到无限,这个并不实际,也不需要。线程总是有限,所以对请求的资源也可限。
共享资源是可以实现的,比如共享的打印机。
②:消除保持和请求条件
就是一个进程一次性请求完所有的资源,不再请求一点资源后,再去执行一些任务。
这样做的缺点就是资源太过浪费,有些进程只有在最后的时候才请求所需的资源,如果一开始就占用,非常影响效率。
③:消除非抢占条件
就是运行进程对别的进程资源的抢占。这也是cpu和内存调度的一个关键。
缺点是,如果在抢占资源时,将一个死锁资源抢占过来,则后果很严重。
④:消除循环等待时间
就是我们设定请求资源的顺序,不再让进程随机无序的请求资源。
相关文章推荐
- 答读者问(9):有关如何看待学校的好坏及如何应对毕业之前的迷茫等问题
- 操作系统--锁的实现的有关问题
- 操作系统清华向勇陈渝版笔记(九) 同步协同多道程序设计和并发问题,同步互斥,死锁,临界区
- Notes: Process in Operation System and Dead Lock 操作系统中的进程和死锁问题
- Notes: Process in Operation System and Dead Lock 操作系统中的进程和死锁问题
- 操作系统试验中有关页架的若干问题
- 有关数据死锁问题的一篇好文章,一个好博客
- 软考中有关死锁的问题
- 操作系统--进程调度的有关问题(2)
- 读书笔记-现代操作系统-3储存管理-3.6有关实现的问题
- 学习向 Solaris 操作系统迁移 C 和 C++ 应用程序的有关问题与技巧
- 死锁的有关问题
- 操作系统学习笔记(12) 死锁问题
- 死锁的有关问题
- 读书笔记-现代操作系统-6死锁-6.7其他问题
- 有关操作系统课程设计课中的几个问题
- 操作系统实验六之死锁问题实验
- 操作系统--进程调度的有关问题(1)
- 有关操作系统课程设计课中的几个问题
- 面试中有关操作系统的问题,持续更新中,,,