Android中的锁——synchronized内置锁和Lock显示锁(自用)

本文深入探讨了Java中的同步机制,包括内置锁(synchronized)和显示锁(ReentrantLock)。内置锁具备可重入性,但不可中断且为非公平锁。显示锁ReentrantLock提供了公平锁的选择,并详细介绍了读写锁的效率优势。同时,文章还提到了死锁问题以及wait(), notify(), notifyAll()在多线程同步中的作用,强调了它们必须在同一锁上使用。

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

内置锁(synchorinized):包括类锁(static修饰)和对象锁(没有static修饰),是可重入锁(自己不会把自己锁死,可内部递归调用自己,能把自己释放出来),是不能中断的,非公平锁
显示锁(Lock): ReentranLock重入锁

Lock lock = new ReentranLock(true); // 传入true,创建一个公平锁

读写锁(ReadWriteLock):速度快

公平锁和非公平锁
死锁:synchronized嵌套

// 都需要在synchronized中使用

wait():等待/冻结,持有的this锁会被释放;可以将线程冻结,释放CPU执行资格,并把此线程临时存储到线程池

notify():鸡肋,当wait多的时候,无法明确唤醒哪一个锁,较少使用;唤醒线程池中任意一个线程,没有执行顺序

notifyAll():大部分都用的notifyAll,因为要保证全部唤醒,并且开源框架中wait较多,无法明确唤醒哪一个;唤醒线程池中的全部线程
以上的前提条件是,三个方法用的都是同一把锁

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值