首页 > 其他分享 >线程同步机制2(死锁)

线程同步机制2(死锁)

时间:2022-12-18 10:44:34浏览次数:38  
标签:释放 同步 Thread 死锁 线程 资源

死锁

1 什么情况下会产生死锁

①. 资源有限
②. 同步嵌套

2 定义:

一般指是同步代码块的嵌套引起的,两个线程各自拿着自己的对象锁不放,造成一个一直僵持的局势

 

 

两个线程都抢到了资源,彼此都在对方释放资源,导致死锁

为避免死锁,在以后的开发中尽量减少同步的资源,减少同步代码块的嵌套结构的使用。

案例

死锁:
    在使用同步代码块的时候,内部使用了嵌套
        (两个线程互相都抢到了资源,彼此都在等待对方释放资源,会导致死锁)

流程:
    线程t1获得了A资源然后进行了加锁,然后进行休眠
    线程t2就获得了B资源然后进行了加锁再等待A释放资源(解锁)
    线程t1休眠结束后在等待t2释放B资源(解锁)
    此时两个线程都在等待对方释放资源(解锁)--> 死锁

public class Demo4 {
public static void main(String[] args) {
    Thread t1 = new Thread(new Runnable() {
        @Override
        public void run() {
            synchronized (A) {
                try {
                    Thread.sleep(100);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
            synchronized (B) {
                    System.out.println("hello...");
                }
            }
        }
    });

    Thread t2 = new Thread(new Runnable() {
        @Override
        public void run() {
            synchronized (B) {
                synchronized (A) {
                    System.out.println("haha...");
                }
            }
        }
    });
}
}

死锁总结

释放锁的操作:

1.同步结束;
2.同步过程中遇见未处理的错误或者异常break等;
3.同步过程中执行了wait()方法,当前线程将会被挂起,释放锁;

不释放锁的操作:

1.同步过程中调用了sleep()或者yield()方法;
2.其他线程调用了该线程的suspend()方法;

 

标签:释放,同步,Thread,死锁,线程,资源
From: https://www.cnblogs.com/Sco-/p/16990075.html

相关文章

  • 线程通信
    一概述:多个线程执行不同任务获取同一个资源,此时需要线程通信来帮助解决线程之间对同一个变量的使用或操作。(避免对同一共享变量的争夺,导致死锁)于是我们引出了等待唤醒机......
  • abp vnext blog模块用户信息同步 源码解析
    先看一下Volo.Blogging.Domain引用的关于用户的项目只有Volo.Abp.Users.Domain,再看BlogUser定义:publicclassBlogUser:AggregateRoot<Guid>,IUser,IUpdateUserD......
  • ollydbg中加载的DLL基地址确定 IDA里IDA:Edit->segments->Rebase program去设置同步
    ollydbg在工具栏E里点击,找到加载的DLL,可以看到基地址,例如下面的就是6CBE0000,IDA里IDA:Edit->segments->Rebaseprogram去设置同步即可!      好了下面是一些......
  • TIDB-DM数据迁移第二部(创建同步任务)
    文档:https://docs.pingcap.com/zh/tidb/stable/quick-start-create-source实验环境源(MySQL):10.255.8.122:3306目标(TiDB):172.16.1.10:3306全量加增量模式,忽略test......
  • redis之单线程
    一、redis为何是单线程官方给出的答案:因为Redis是基于内存的操作,CPU不会成为Redis的瓶颈,而最有可能是机器内存的大小或者网络带宽。既然单线程容易实现,而且CPU不......
  • ThreadPoolExecutor创建线程池启动项目报错问题
    ThreadPoolExecutor创建线程,如下代码:ThreadPoolExecutorthreadPoolExecutor=newThreadPoolExecutor(Runtime.getRuntime().availableProcessors()+1,20,......
  • 线程常用方法
    线程常用方法介绍1、方法概述方法说明static功能说明注意start()启动一个新线程,在新的线程运行run方法中的代码start方法只是让线程进入就绪,里面代码不一......
  • Python之threading: 带你了解多线程的强大威力!
    前言什么是多线程多线程是指在一个程序中同时创建和使用多个执行流(thread)来执行不同的任务。这样多个任务就可以同时进行,从而提高程序的执行效率。在python使用多线......
  • 创建线程的4种方法
    线程创建方法1、继承Thread,重写run方法 privatestaticvoidone(){classTextendsThread{@Overridepublicvo......
  • python多线程修改共享全局变量不安全
    当需要对全局变量进行更改时,则会出现不安全的情况 #-*-coding:utf-8-*-"""================================================================================......