线程死锁

本文介绍了Java中线程死锁的概念,通过一个扫描仪和打印机的实例展示了死锁的发生,并分析了导致死锁的原因。为避免死锁,提出了限制锁的获取数量、规范锁的获取顺序以及设置等待超时等策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、死锁的定义

 所谓死锁是指两个或两个以上的线程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去。

二、死锁产生的原因

1.资源有限;

2.锁嵌套;

3.不强制剥夺线程占有的资源。

三、死锁案例代码:

以扫描仪和打印机为例,有多个线程争夺这两个共享资源的使用权

打印机类:

package cc.zxf.owner.vip.lineLock;

/**
 * 打印机类
 */
public class Print {

    public void printing(){
        System.out.println("打印机开始工作!!!!!");
    }

}

扫描仪类:

package cc.zxf.owner.vip.lineLock;

/**
 * 扫描仪类
 */
public class Scan {

    public void scaning(){
        System.out.println("扫描仪开始工作!!!!!");
    }

}

测试类:

package cc.zxf.owner.vip.lineLock;

/**
 * 线程死锁
 */
public class TestDeadLock {

    private static Print print = new Print();

    private static Scan scan = new Scan();

    private static class work1 extends Thread{
        @Override
        public void run() {
            System.out.println("线程:"+Thread.currentThread().getId()+" 开始获取扫描仪!!");
            synchronized (scan){
                scan.scaning();
                try {
                    Thread.sleep(3000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println("线程:"+Thread.currentThread().getId()+" 开始获取打印机!!");
                synchronized (print){
                    print.printing();
                }
            }
        }
    }

    private static class work2 extends Thread{
        @Override
        public void run() {
            System.out.println("线程:"+Thread.currentThread().getId()+" 开始获取打印机!!");
            synchronized (print){
                print.printing();
                try {
                    Thread.sleep(3000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                System.out.println("线程:"+Thread.currentThread().getId()+" 开始获取扫描仪!!");
                synchronized (scan){
                    scan.scaning();
                }
            }
        }
    }

    public static void main(String[] args){

        work1 work1 = new work1();

        work2 work2 = new work2();

        work1.start();

        work2.start();

    }

}

执行结果:

四、如何避免死锁:

1、让程序每次至多只能获得一个锁。

2、设计时考虑清楚锁的顺序,尽量减少嵌套的加锁交互数量。

3、既然死锁的产生是两个线程无限等待对方持有的锁,那么只要在等待时间上加个上限就好了。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Netocc

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值