教培参考
教育培训行业知识型媒体
发布时间: 2024年11月23日 20:49
无论是客户端还是服务器端多线程Java程序,最常见的多线程问题包括死锁、隐性死锁和数据竞争。
1、死锁
多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放。由于线程被无限期地阻塞,因此程序不可能正常终止。
导致死锁的根源在于不适当地运用“synchronized”关键词来管理线程对特定对象的访问。“synchronized”关键词的作用是确保在某个时刻只有一个线程被允许执行特定的代码块,因此,被允许执行的线程首先必须拥有对变量或对象的排他性的访问权。当线程访问对象时,线程会给对象加锁,而这个锁导致其它也想访问同一对象的线程被阻塞,直至第一个线程释放它加在对象上的锁。
2、隐性死锁
隐性死锁由于不规范的编程方式引起,但不一定每次测试运行时都会出现程序死锁的情形。由于这个原因,一些隐性死锁可能要到应用正式发布之后才会被发现,因此它的危害性比普通死锁更大。下面介绍两种导致隐性死锁的情况:加锁次序和占有并等待。
3、加锁次序
当多个并发的线程分别试图同时占有两个锁时,会出现加锁次序冲突的情形。如果一个线程占有了另一个线程必需的锁,就有可能出现死锁。注意,在代码丝毫不做变动的情况下VM调度程序可能让其中一个线程同时获得两个锁,即线程获取两个锁的过程没有被中断,在这种情形下,常规的死锁检测很难确定错误所在。
还有一部分Java初学者通过Thread类创建Java多线程时会跳入这样的坑:创建线程对象后,调用的是线程对象的start的方法,而不是run方法。虽然两个方法都能执行run里面的代码,但本质上是不一样的。我们不能对同一个线程同时执行start方法,如果需要执行多次,就必须再new一个线程对象去start。
想了解更多Java入门规避错误点或快速提升进阶Java技术,你可以关注“优逸客科技”微信公众号,定期发布技术热点和行业分析。你也可以来优逸客太原Java培训班进行系统的学习,期间有专业的大牛讲师讲解潮流高端的课程,还有专业的职业规划师给你求职指引,让你高效学习、快速就业!