乐观锁
什么是乐观锁?
顾名思义, 就是什么都往好处想的锁, 总是认为被人来读数据不会对数据进行修改, 所以不上锁, 但是在更新的时候会判断一下在此期间别人有没有去更新这个数据
适用场景:
适用于写比较少的情况下
实现方式:
- 版本号机制: 在表中加入一个version字段, 表示该条记录被修改的次数, 当某个线程来读取数值时也会读取version, 在对其进行更新提交后会核对version字段是否和自己读到的version相同, 如果和刚才读到的version值不同那么会重试读-更新-查看version操作, 直到更新成功(此时让version+1)
- CAS算法
悲观锁
什么是悲观锁?
把任何情况都想到最坏, 每次拿到资源就会上锁, 此时其他想要使用该资源的线程会阻塞, 直到对资源使用完成才会释放该资源
适用场景:
适用于多写的场景
实现方式:
关系型数据库的行锁, 表锁, 写锁, 读锁, synchronized, ReentrantLock等都是悲观锁的实现