重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要介绍Java多线程中死锁有什么用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
公司主营业务:成都网站设计、成都网站制作、移动网站开发等业务。帮助企业客户真正实现互联网宣传,提高企业的竞争能力。创新互联是一支青春激扬、勤奋敬业、活力青春激扬、勤奋敬业、活力澎湃、和谐高效的团队。公司秉承以“开放、自由、严谨、自律”为核心的企业文化,感谢他们对我们的高要求,感谢他们从不同领域给我们带来的挑战,让我们激情的团队有机会用头脑与智慧不断的给客户带来惊喜。创新互联推出万载免费做网站回馈大家。
所谓线程死锁是指两个或两个以上的线程互相持有对方所需要的资源,由于synchronized的特性,一个线程持有一个资源,或者说获得一个锁,在该线程释放这个锁之前,其它线程是获取不到这个锁的,而且会一直死等下去,因此这便造成了死锁。
如下图(1-1):
Java多线程中死锁产生的必要条件如下:
1.互斥条件:一个资源,或者说一个锁只能被一个线程所占用,当一个线程首先获取到这个锁之后,
在该线程释放这个锁之前,其它线程均是无法获取到这个锁的;
2.占有且等待:一个线程已经获取到一个锁,再获取另一个锁的过程中,即使获取不到也不会释放已
经获得的锁;
3.不可剥夺条件:任何一个线程都无法强制获取别的线程已经占有的锁;
4.循环等待条件:线程A拿着线程B的锁,线程B拿着线程A的锁;
当满足以上四个条件时,就出现死锁的情况!!!
public class DeadLock implements Runnable {
//创建两个锁对象
private Object lock1=new Object();
private Object lock2=new Object();
@Override
public void run(){
while(true){
method1();
method2();
}
}
public void method1(){
synchronized (lock1){
System.out.println(Thread.currentThread().getName() + “获取到lock1”);
try {
Thread.sleep(1000); //线程休眠,使得CPU切换
} catch (InterruptedException e) {
e.printStackTrace();
}
synchronized (lock2){
System.out.println(Thread.currentThread().getName() + "获取到lock2");
}
}
}
public void method2(){
synchronized (lock2){
System.out.println(Thread.currentThread().getName() + "获取到lock2");
synchronized (lock1){
System.out.println(Thread.currentThread().getName() + "获取到lock1");
}
}
}
public static void main(String[] args) {
DeadLock deadLock = new DeadLock();
new Thread(deadLock).start();
new Thread(deadLock).start();
}
}
(图3-1)
这样便造成了死锁,Thread1拿着lock1,想要lock2,Thread2拿着lock2,想要lock1.
Java多线程中如何避免死锁:
1.加锁顺序:线程按照相同的顺序加锁。
2.加锁时限,线程获取锁的过程中限制一定的时间,如果给定时间内获取不到,就算了,别勉强自
己。这需要用到Lock的一些API
在发生死锁之后,程序就卡住了没有任何反应,但程序仍在运行,因此需要借助一些
1.首先使用 jps -l 显示正在运行的虚拟机进程,并显示虚拟机执行主类(main函数所在
的类)名称以及这些进程的本地虚拟机唯一ID
图(5-1)
2.使用 jstack + id 进行跟踪排查
图(5-2)
图(5-3)
以上是“Java多线程中死锁有什么用”这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注创新互联行业资讯频道!