作用
用一个锁所住一组相关的对象
粗粒度锁是覆盖多个对象的单个锁,这样不仅简化了加锁行为本身,而且让你不必为了给它们加锁所而加载所有的对象。
运行机制
- 实现粗粒度锁的第一步是为一组对象建立一个控制点,使得只用一个锁就能锁住多个对象。
- 用乐观离线锁让组中每个对象都共享同一个版本号来建立一个控制点。
- 用悲观离线锁,可以让组中每个成员共享锁标记。
一簇相关对象都存在一个唯一的、提供对集合各成员访问的根对象。加锁时,需要一个到根对象的搜索方法。
用共享锁或根对象锁实现粗粒度锁有一定的折中:用关系数据库时,共享锁会导致几乎所有的查询语句都和版本表version关联;使用悲观离线锁时,可能总是要重新读取一些对象来保证它们是新的。
使用时机
使用粗粒度锁可以使获取和释放锁的代价很小。
示例-共享的乐观离线锁(Java)
step1:构造版本类-目的是在领域对象聚集范围内共享
注意,删除版本记录表明释放锁,但是决不允许这种情况发生:
删除操作的返回行数为0,这说明版本记录已经被删除了。删除某版本的数据时并没有获得乐观离线锁。
step2:创建领域对象-顾客和顾客地址
step3:使用版本对象
step4:如果是删除操作,则删除客户时还要删除地址信息