服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - Java教程 - Java多线程产生死锁的必要条件

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

2021-06-28 10:39李灿辉 Java教程

今天小编就为大家分享一篇关于Java多线程产生死锁的必要条件,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

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

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

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

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

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

  • 1,必须有2个或以上的线程。一个线程是不会产生死锁的,它顶多产生等待。
  • 2,必须有2个临界资源,即,必须有2个锁。这也是死锁产生的必要的条件。当只有一个临界资源,或者说只有一个锁时,当一个线程获取了锁,另一个线程虽然暂时无法获取锁,但它至多也就是需要进行等待。而不会陷入死锁。
  • 3,两个线程,每个线程都获取了其中的一个锁,但为了完成工作,还需对方的另一个锁。这种情况下,才会产生死锁。这种情况也称为循环等待。
  • 4,不可剥夺。

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

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

  • 固定加锁的顺序(针对锁顺序死锁)
  • 开放调用(针对对象之间协作造成的死锁)
  • 使用定时锁-->trylock()

总结

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

原文链接:https://blog.csdn.net/li_canhui/article/details/85298236

延伸 · 阅读

精彩推荐