悲观锁: 总是假设最坏的情况,每次去拿数据的时候都认为别人会修改,所以每次在
拿数据的时候都会上锁,这样别人想拿这个数据就会阻塞直到它拿到锁。
乐观锁: 对于锁的态度比较乐观, 认为每次获取数据或修改数据时, 不会出现并发冲
突, 所以不会上锁, 但在数据更新提交之前, 会判断数据是否产生并发冲突
进行检测 , 如果发现并发冲突 , 则让返回用户错误的信息,让用户决定如
何去做。
举个例子:
同学 A 认为 "老师是比较忙的, 我来问问题, 老师不一定有空解答". 因此同
学 A 会先给老师发消息: "老师 你忙嘛? 我下午两点能来找你问个问题嘛?"
(相当于加锁操作) 得到肯定的答复之后, 才会真的来问问题. 如果得到了否
定的答复, 那就等一段时间, 下次再来和老师确定时间. 这个是悲观锁.
同学 B 认为 "老师是比较闲的, 我来问问题, 老师大概率是有空解答的". 因此同学 B 直接就来找老师.(没 加锁, 直接访问资源) 如果老师确实比较闲, 那么直接问题就解决了. 如果老师这会确实很忙, 那么同学 B 也不会打扰老师, 就下次再来(虽然没加锁, 但是能识别出数据访问冲突). 这个是乐观锁.
注意: Synchronized 可以说是一个自适应锁 , 它会根据当前的锁竞争激烈强度 ,来调
整锁策略, 初始使用乐观锁策略. 当发现锁竞争比较频繁的时候, 就会自动切换
成悲观锁策略.