活跃性故障
当出现活跃性故障时,中止应用程序并且尝试重启
(一)死锁
锁顺序死锁:两个方法间锁不按照顺序调用导致死锁
动态锁顺序死锁:两个线程调用一个方法,调用方法过程中不按顺序调用锁导致死锁。通过锁顺序避免死锁。
协作对象之间发生死锁:两个对象间,解决办法,放开调用(同步方法改成同步块)
资源死锁:有界线程池/资源池与相互依赖的任务不能一起使用。
死锁的避免:避免死多确保线程在获取多个锁时采用一致的顺序。
1、放开调用:在确保不需要方法原子性的基础上,将同步方法改成同步块。减少需要同时持有多个锁的地方。
2、支持定时的锁:使用Lock类中定时的tryLoc代替内置锁机制。在等待超时后,tryLock会返回一个失败信息。
(二)饥饿:避免使用线程的优先级,因为会增加平台的依赖性,并可能导致活跃性问题。可以通过Thread.sleep()和Thread.yield()克服优先级调整或者响应性问题。
(三)糟糕的响应性:不良锁的管理,eg某个线程长时间占有一个锁,而其他想要访问这个容器的线程就必须等待很长的时间。可以使用类似的同步容器代替。
(四)活锁:很有礼貌的两个锁相互让。通过等待随机长度的时间和回退可以有效避免活锁的发生。