悲观锁和乐观锁的区别

1.悲观锁是当线程拿到资源时,就对资源上锁,并在提交后,才释放锁资源,其他线程才能使用资源。

2.乐观锁是当线程拿到资源时,上乐观锁,在提交之前,其他的锁也可以操作这个资源,当有冲突的时候,并发机制会保留前一个提交,打回后一个提交,让后一个线程重新获取资源后,再操作,然后提交。和git上传代码一样,两个线程都不是直接获取资源本身,而是先获取资源的两个copy版本,然后在这两个copy版本上修改。

3.悲观锁和乐观锁在并发量低的时候,性能差不多,但是在并发量高的时候, 乐观锁的性能远远优于悲观锁。

4.我们常用的synchronized是悲观锁,lock是乐观锁 。他们之间的区别详见于Java同步锁——lock与synchronized 的区别【转】

5.还有一个乐观锁的例子 https://www.cnblogs.com/darrenqiao/p/9211447.html

posted @ 2019-07-23 11:46  Mop猎人  阅读(6869)  评论(0编辑  收藏  举报