3.9、多把锁

本文通过示例介绍了如何使用细粒度锁来提升并发度,以解决多个线程在共享资源时的冲突问题。通过为不同操作分配不同的锁对象,小南和小女可以同时在同一个房间内进行学习和睡眠而不会相互阻塞。然而,这种方法虽然提高了并发性,但也增加了死锁的可能性,当一个线程同时获取多把锁时可能会导致死锁状态。

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

多把不相干的锁

一间屋子有两个功能:睡觉、学习,互不相干

现在小南要学习,小女要睡觉,但如果只用一间屋子(一把锁)的话,那么并发度很低

解决方法是准备多个房间(多个对象锁)

例如

@Slf4j(topic = "c.BigRoom")
class BigRoom {

    public void sleep() {
        synchronized (this) {
            log.debug("sleep 2小时");
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

    public void study() {
        synchronized (this) {
            log.debug("study 1小时");
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

执行

		BigRoom bigRoom = new BigRoom();
        new Thread(() -> {
            bigRoom.sleep();
        },"小南").start();

        new Thread(() -> {
            bigRoom.study();
        },"小女").start();

输出

2022/03/06-18:11:07.948 [小南] c.BigRoom - sleep 2小时
2022/03/06-18:11:09.960 [小女] c.BigRoom - study 1小时

改进

@Slf4j(topic = "c.BigRoom")
class BigRoom {

    private final Object sleepRoom = new Object();
    private final Object studyRoom = new Object();

    public void sleep() {
        synchronized (sleepRoom) {
            log.debug("sleep 2小时");
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }

    public void study() {
        synchronized (studyRoom) {
            log.debug("study 1小时");
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}

输出

2022/03/06-18:13:35.248 [小南] c.BigRoom - sleep 2小时
2022/03/06-18:13:35.248 [小女] c.BigRoom - study 1小时

将锁粒度细分

  • 好处、可以增强并发度
  • 坏处、如果一个线程同时获得多把锁,就容易发生死锁
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值