线程死锁|学习笔记

简介: 快速学习 线程死锁

开发者学堂课程【Java 高级编程线程死锁】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址:https://developer.aliyun.com/learning/course/20/detail/292


线程死锁


死锁

死锁是在进行多线程同步的处理之中有可能产生的一种问题,所谓的死锁指的是若干个线程彼此互相等待的状态。

下面通过简单的代码来观察一下死锁的表现形式但是对于此代码不作为重点。

 

范例:死锁的展示

package cn.mldn.demo;

class MyThread implements Runnable i

private int ticket = 10 ; l/总票数为1日张public synchrbnized boolean sale() {

if (this.ticket > ) {

try {

Thread.sleep( 100); //模拟网络延迟

}catch ( InterruptedException e) {

e.printStackTrace();

}

System.out.println(Thread.currentThread( ).getName() +“卖票,ticket = " + this.ticket --);

return true ;

}else {

System.out.println("*****票已经卖光了*****");

return false ;

}

}

@override

public void run() {

while (this.sale()) {

;

}

}

package cn.mldn. demo;

class ian {

public synchronized void say (xiaoQiang xq) {

system.out.println("阿健说:此路是我开,要想从此过,留下10块钱。");

}

public synchronized void get() i

system.out.println("阿健说。得到了10块钱,可以买饭吃了,于是让出了路。");

class xiaoQiang {

public synchronized void say ( ian jj) {

system.out.print1n( "小强说:让我先跑,我再给你钱。");

}

public synchronized void get() {

System.out.println( "小强说:逃过了一劫,可以继续送快餐了。");

public class DeadLock implements Runnable k

@override

public void run( ) {

//TODO Auto-generated method stub

}

}

现在死锁造成的主要原因是因为彼此都在互相等待着,等待着对方先让出资源。

死锁实际上是一种开发中出现的不确定的状态,有的时候代码如果处理不当则会不定期出现死锁,这是属于正常开发中的调试问题。

若干个线程访问同一资源时一定要进行同步处理,而过多的同步会造成死锁。

相关文章
|
编解码 数据安全/隐私保护 计算机视觉
Opencv学习笔记(十):同步和异步(多线程)操作打开海康摄像头
如何使用OpenCV进行同步和异步操作来打开海康摄像头,并提供了相关的代码示例。
856 1
Opencv学习笔记(十):同步和异步(多线程)操作打开海康摄像头
多线程学习笔记
这篇文章是多线程学习笔记,涵盖了线程与进程的概念、多线程实现方式、线程状态、线程同步与不安全示例、死锁问题以及生产者与消费者问题等多线程编程的关键知识点。
多线程学习笔记
FFmpeg学习笔记(二):多线程rtsp推流和ffplay拉流操作,并储存为多路avi格式的视频
这篇博客主要介绍了如何使用FFmpeg进行多线程RTSP推流和ffplay拉流操作,以及如何将视频流保存为多路AVI格式的视频文件。
1393 0
|
安全 Java 程序员
【多线程-从零开始-肆】线程安全、加锁和死锁
【多线程-从零开始-肆】线程安全、加锁和死锁
252 0
|
安全 算法 Java
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)(下)
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)
214 6
|
存储 安全 Java
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)(中)
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)
241 5
|
存储 安全 Java
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)(上)
17 Java多线程(线程创建+线程状态+线程安全+死锁+线程池+Lock接口+线程安全集合)
180 3
|
Arthas 监控 Java
深入解析与解决高并发下的线程池死锁问题
在高并发的互联网应用中,遇到线程池死锁问题导致响应延迟和超时。问题源于库存服务的悲观锁策略和线程池配置不当。通过以下方式解决:1) 采用乐观锁(如Spring Data JPA的@Version注解)替换悲观锁,减少线程等待;2) 动态调整线程池参数,如核心线程数、最大线程数和拒绝策略,以适应业务负载变化;3) 实施超时和重试机制,减少资源占用。这些改进提高了系统稳定性和用户体验。
680 2
|
Java
死锁是线程间争夺资源造成的无限等待现象,Java示例展示了两个线程各自持有资源并等待对方释放,导致死锁。`
【6月更文挑战第20天】死锁是线程间争夺资源造成的无限等待现象,Java示例展示了两个线程各自持有资源并等待对方释放,导致死锁。`volatile`保证变量的可见性和部分原子性,确保多线程环境中值的即时更新。与`synchronized`相比,`volatile`作用于单个变量,不保证原子操作,同步范围有限,但开销较小。`synchronized`提供更全面的内存语义,保证原子性和可见性,适用于复杂并发控制。
146 3
|
Java
在Java中,死锁是指两个或多个线程互相等待对方释放资源,从而导致所有线程都无法继续执行的情况。
【6月更文挑战第24天】在Java并发中,死锁是多线程互相等待资源导致的僵局。避免死锁的关键策略包括:防止锁嵌套,设定固定的加锁顺序,使用`tryLock`带超时,避免无限等待,减少锁的持有时间,利用高级同步工具如`java.util.concurrent`,以及实施死锁检测和恢复机制。通过这些方法,可以提升程序的并发安全性。
141 1

热门文章

最新文章