并发编程 高级主题篇

显示锁
ReentrantLock实现了Lock接口,内置锁无法中断一个正在获取锁的线程,无法再获取一个锁无限等待下去。必须在获取该锁的代码块释放,却无法实现非阻塞结构的加锁规则。
使用Lock锁,必须在finally中释放锁,否则,如果在被保护的代码中抛出了异常,锁将永远无法释放。必须考虑在try中抛出异常的情况
用ReentrantLock保护对象状态如果没有用finally来释放Lock,很难追踪到错误点,此乃ReemtrantLock不能玩去拿替代synchronized原因
并发编程 高级主题篇
轮询锁和定时锁由tryLock方法实现的,具狗i就有更完善的错误恢复机制。在内置锁,死锁很严重,唯一恢复办法是重启程序,防止办法是构建时候整理好锁顺序,可定时与可轮询锁是一个选择。

下面用tryLock来获取两个锁,如果不能同时获取,回退重试,休眠时间包括固定,随机部分,规避活锁,如果在指定时间内不能获取需要的锁,返回一个失败状态。
并发编程 高级主题篇
以前如图过的串行访问方法一种是单线程的Executor,另一种是使用一个独占锁保护对资源访问,定时的tryLock能在带有时间限制的操作中实现独占加锁的行为。
并发编程 高级主题篇
可中断的锁获取 lockInterruptibly能在获得锁的同时保持对中断响应,不用创建不可阻塞机制并发编程 高级主题篇
显示锁和内置锁,内置锁synchronized无法满足的时候可以用显示锁ReentrantLock,功能包括可定是,可轮询 可终端的锁获取操作。
读写锁,如果允许多个读操作同时访问数据结构,将提升程序性能。保证读最新且过程不会被修改的数据。多个读或者一个写
并发编程 高级主题篇
在map中要实现读写并发操作,可以用如下方法
并发编程 高级主题篇
与内置锁相比,显示Lock提供了扩展功能,处理锁的不可用性能访民啊有更高灵活性,对队列有更好控制,当synchronized无法满足条件,才能使用ReentrantLock