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

死锁,饥饿,活锁

1,死锁

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

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

2,饥饿

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

出现饥饿的三种情况

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

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

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

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

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

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

如何避免饥饿问题

a,设置合理的优先级

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

3,活锁

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

你可能感兴趣的:(高并发编程-05-活跃性问题)