Java多线程产生死锁的必要条件

网友投稿 237 2023-01-15


Java多线程产生死锁的必要条件

线qCtkEbxKp程死锁是指由于两个或者多个线程互相持有对方所需要的资源,导致这些线程处于等待状态,无法前往执行。当线程进入对象的synchronized代码块时,便占有了资源,直到它退出该代码块或者调用wait方法,才释放资源,在此期间,其他http://线程将不能进入该代码块。当线程互相持有对方所需要的资源时,会互相等待对方释放资源,如果线程都不主动释放所占有的资源,将产生死锁。

死锁是操作系统里里面的一个重要的概念,死锁通常发生在并发的场景里。

死锁是多个进程或线程,彼此争抢资源而陷入僵局的一种情况。

在笔者参加的多次面试中,发现不少候选人虽然大概知道死锁是一种因为争抢资源引起的问题,但真的要写一个死锁的例子的话,还是有不少候选人不知道该如何下手。

其实,真正理清楚了死锁产生的必要的条件,写出一个死锁的例子并不困难。那么,就java的多线程而言,产生死锁有哪些必要条件呢?

1,必须有2个或以上的线程。一个线程是不会产生死锁的,它顶多产生等待。

2,必须有2个临界资源,即,必须有2个锁。这也是死锁产生的必要的条件。当只有一个临界资源,或者说只有一个锁时,当一个线程获取了锁,另一个线程虽然暂时无法获取锁,但它至多也就是需要进行等待。而不会陷入死锁。

3,两个线程,每个线程都获取了其中的一个锁,但为了完成工作,还需对方的另一个锁。这种情况下,才会产生死锁。这种情况也称为循环等待。

http:// 4,不可剥夺。

以上即为死锁产生的必要条件。

避免死锁可以概括成三种方法:

固定加锁的顺序(针对锁顺序死锁)

开放调用(针对对象之间协作造成的死锁)

使用定时锁-->tryLock()

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对我们的支持。如果你想了解更多相关内容请查看下面相关链接


版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Spinrg WebFlux中Cookie的读写的示例
下一篇:在Spring中使用JDBC和JDBC模板的讲解
相关文章

 发表评论

暂时没有评论,来抢沙发吧~