死锁

作者: Cheep | 来源:发表于2020-07-09 15:17 被阅读0次

死锁四个条件:

1.互斥条件:(一个资源只能被一个进程占用)
2.不可剥夺条件:(某个进程占有的资源,只有这个进程能释放)
3.循环条件:(多个进程之间 首尾相接的循环等待资源)
4.请求和保持条件:(进程会去请求资源,但是持有资源会保持不变,不释放)
上述的“进程”可以理解成“线程”

死锁例子:

public class TestDeadLock{
    Object wait1 = new Object();
    Object wait2 = new Object();
    private void test1(){
        try{
            synchronized(wait1){
                System.out.println("join test1 start...");
                Thread.sleep(1000);
                synchronized(wait2){
                    System.out.println("test1 抢wait2锁成功...");
                }
                System.out.println("join test1 end...");
            }
        }catch(InterruptedException e){
            e.printStackTrace();
        }
    }
    
    private void test2(){
        try{
            synchronized(wait2){
                System.out.println("join test2 start...");
                Thread.sleep(1000);
                synchronized(wait1){
                    System.out.println("test2 抢wait1锁成功...");
                }
                System.out.println("join test2 end...");
            }
        }catch(InterruptedException e){
            e.printStackTrace();
        }
    }
    
    public static void main(String[] args) {
        LockLockTest lock = new LockLockTest();
        new Thread(new Runnable(){
            @Override
            public void run(){
                lock.test1();
            }
        }).start();
        
        new Thread(new Runnable(){
            @Override
            public void run(){
                lock.test2();
            }
        }).start();
    }
}

打印结果:
    join test1 start...
    join test2 start...

解读上述代码:

1.synchronized 就是满足死锁条件----互斥条件----

2.test1方法占用wait1资源 (synchronized(wait1))和 test2方法占用wait2资 源(synchorized(wait2)---不可剥夺条件---

3.test1 保持资源wait1请求资源wait2
test2 保持资源wait2 请求资源wait1

---请求和保持条件---
synchorized(wait1){
    ...
    syschorized(wait2){
    ...
    }
    ...
}
和
synchorized(wait2){
    ...
    syschorized(wait1){
    ...
    }
    ...
}

4.synchorized同时有两个进程争夺,就会升级为轻量级锁,也可以理解自旋锁。
例如:wait1资源目前A线程持有。B线程获取wait1资源,目前已被占有,只能CAS自旋等待资源。
---循环等待---

相关文章

  • 死锁

    线程饥饿死锁 锁顺序死锁 动态锁顺序死锁通过锁顺序来避免死锁 避免死锁

  • 死锁

    第11章:死锁和进程通信 死锁概念 死锁处理方法 死锁预防(Deadlock Prevention) 死锁避免(D...

  • java多线程笔记

    产生死锁的四个必要条件 处理死锁的基本方法 死锁预防 死锁避免 死锁检测 死锁解除 https://blog.cs...

  • [现代操作系统]--死锁

    table of content 死锁定义 死锁建模-- 资源分配图 处理死锁鸵鸟算法检测并恢复死锁检测死锁恢复利...

  • Java-多线程(四)死锁

    死锁 死锁示例

  • Java死锁

    什么是死锁 死锁检测 产生死锁的四个必要条件 如何避免死锁 死锁 死锁,指两个或多个线程之间,由于互相持有对方需要...

  • java并发--java死锁

    本篇结构: 前言 什么是死锁 产生死锁的必要条件 死锁的代码示例 死锁排查 如何避免死锁 总结 一、前言 今天被问...

  • Java多线程之死锁(Deadlock)及死锁避免(Deadlo

    线程死锁(Thread Deadlock) 数据库死锁(Database Deadlocks) 死锁避免 (Dea...

  • JavaEE面试题总结 Day39 2018-12-29

    什么是线程死锁?死锁如何产生?如何避免线程死锁? 死锁的介绍: 线程死锁是指由于两个或者多个线程互相持有对方所需要...

  • Java并发之嵌套管程锁死(Nested Monitor Loc

    嵌套管程死锁是如何发生的 具体的嵌套管程死锁的例子 嵌套管程死锁 vs 死锁 嵌套管程锁死类似于死锁, 下面是一个...

网友评论

      本文标题:死锁

      本文链接:https://www.haomeiwen.com/subject/wfcscktx.html