码迷,mamicode.com
首页 > 其他好文 > 详细

高并发编程-05-活跃性问题

时间:2018-01-12 14:19:14      阅读:135      评论:0      收藏:0      [点我收藏+]

标签:syn   top   优先级   唤醒   color   border   ros   UI   cpu   

死锁,饥饿,活锁

1,死锁

多个线程,各自占对方的资源,都不愿意释放,从而造成死锁

工具:使用jconsole可以检测程序运行的死锁线程

2,饥饿

多个线程访问同一个同步资源,有些线程总是没有机会得到互斥锁,这种就叫做饥饿。

出现饥饿的三种情况

a,高优先级的线程吞噬了低优先级的线程的CPU时间片

理论上来说,线程优先级高的线程会比线程优先级低的线程获得更多的执行机会,但是java的线程优先级绝对出现这样的效果。

经过测试,优先级高的出现频率会比优先级低的高很多

不同的操作系统对线程的优先级支持是不同的,规定是在1-10之间,java通过3个常量来屏蔽这种操作系统的底层差异化。

b,线程被永久阻塞在等待进入同步代码块的状态

c,等待的线程永远不被唤醒

如何避免饥饿问题

a,设置合理的优先级

b,使用公平锁来代替synchronized这种互斥锁

3,活锁

举个例子,两个人在走廊上碰见,大家都互相很有礼貌,互相礼让,A从左到右,B也从从左转向右,发现又挡住了地方,继续转换方向,但又碰到了,反反复复,一直没有机会运行下去。


高并发编程-05-活跃性问题

标签:syn   top   优先级   唤醒   color   border   ros   UI   cpu   

原文地址:http://blog.51cto.com/huangguizhao/2060198

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!