Java并发编程实战(四)活跃性

活跃性故障

当出现活跃性故障时,中止应用程序并且尝试重启

(一)死锁

锁顺序死锁:两个方法间锁不按照顺序调用导致死锁

动态锁顺序死锁:两个线程调用一个方法,调用方法过程中不按顺序调用锁导致死锁。通过锁顺序避免死锁。

协作对象之间发生死锁:两个对象间,解决办法,放开调用(同步方法改成同步块)

资源死锁:有界线程池/资源池与相互依赖的任务不能一起使用。


死锁的避免:避免死多确保线程在获取多个锁时采用一致的顺序。

1、放开调用:在确保不需要方法原子性的基础上,将同步方法改成同步块。减少需要同时持有多个锁的地方。

2、支持定时的锁:使用Lock类中定时的tryLoc代替内置锁机制。在等待超时后,tryLock会返回一个失败信息。

(二)饥饿:避免使用线程的优先级,因为会增加平台的依赖性,并可能导致活跃性问题。可以通过Thread.sleep()和Thread.yield()克服优先级调整或者响应性问题。

(三)糟糕的响应性:不良锁的管理,eg某个线程长时间占有一个锁,而其他想要访问这个容器的线程就必须等待很长的时间。可以使用类似的同步容器代替。

(四)活锁:很有礼貌的两个锁相互让。通过等待随机长度的时间和回退可以有效避免活锁的发生。

发布了51 篇原创文章 · 获赞 24 · 访问量 8万+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章