死锁:
1)互斥条件:指进程对所分配到的资源进行排它性使用,即在一段时间内某资源只由一个进程占用。如果此时还有其它进程请求资源,则请求者只能等待,直至占有资源的进程用毕释放。
2)请求和保持条件:指进程已经保持至少一个资源,但又提出了新的资源请求,而该资源已被其它进程占有,此时请求进程阻塞,但又对自己已获得的其它资源保持不放。
3)不剥夺条件:指进程已获得的资源,在未使用完之前,不能被剥夺,只能在使用完时由自己释放。
4)环路等待条件:指在发生死锁时,必然存在一个进程——资源的环形链,即进程集合{P0,P1,P2,···,Pn}中的P0正在等待一个P1占用的资源;P1正在等待P2占用的资源,……,Pn正在等待已被P0占用的资源。
活锁:
活锁指的是任务或者执行者没有被阻塞,由于某些条件没有满足,导致一直重复尝试,失败,尝试,失败。 活锁和死锁的区别在于,处于活锁的实体是在不断的改变状态,所谓的“活”, 而处于死锁的实体表现为等待;活锁有可能自行解开,死锁则不能。
活锁可以认为是一种特殊的饥饿。 下面这个例子在有的文章里面认为是活锁。实际上这只是一种饥饿。因为没有体现出“活”的特点。 假设事务T2再不断的重复尝试获取锁R,那么这个就是活锁。
饥饿:
饥饿 ,与死锁和活锁非常相似。是指一个可运行的进程尽管能继续执行,但被调度器无限期地忽视,而不能被调度执行的情况。[饥饿可以通过先来先服务资源分配策略来避免。
关于多线程死锁、活锁、饥饿
原创CharlesYooSky ©著作权
©著作权归作者所有:来自51CTO博客作者CharlesYooSky的原创作品,请联系作者获取转载授权,否则将追究法律责任
上一篇:JVM 内存结构
下一篇:Redis常问的面试题
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
Java多线程的死锁,活锁,饥饿
..
死锁 公平锁 使用场景 -
死锁与活锁
占用的道路(死锁发生条件2:必须整条车身的空间才能开过去,...
死锁 公平锁 使用场景 -
高并发编程-05-活跃性问题-死锁,活锁,饥饿
讲解高并发的活跃度问题
高并发 高性能 死锁 -
读写锁中写锁的饥饿问题
引言
读写锁 读锁 数据