悲观锁和乐观锁的区别
1.悲观锁是当线程拿到资源时,就对资源上锁,并在提交后,才释放锁资源,其他线程才能使用资源。
2.乐观锁是当线程拿到资源时,上乐观锁,在提交之前,其他的锁也可以操作这个资源,当有冲突的时候,并发机制会保留前一个提交,打回后一个提交,让后一个线程重新获取资源后,再操作,然后提交。和git上传代码一样,两个线程都不是直接获取资源本身,而是先获取资源的两个copy版本,然后在这两个copy版本上修改。
3.悲观锁和乐观锁在并发量低的时候,性能差不多,但是在并发量高的时候, 乐观锁的性能远远优于悲观锁。
4.我们常用的synchronized是悲观锁,lock是乐观锁 。他们之间的区别详见于Java同步锁——lock与synchronized 的区别【转】;
5.还有一个乐观锁的例子 https://www.cnblogs.com/darrenqiao/p/9211447.html