悲观锁与乐观锁以及如何用java语言和mysql实现

Posted luffy5459

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了悲观锁与乐观锁以及如何用java语言和mysql实现相关的知识,希望对你有一定的参考价值。

    悲观锁,乐观锁跟字面意思一样,悲观锁认为在多线程场景下,不一定能够获取资源,所以要先获取锁,再做相关业务,保证不会发生冲突。乐观锁认为多线程场景下,不会发生冲突,所以不用先加锁,等到有并发的时候再去加锁。

    悲观锁在java语言中,就是各种Lock的实现,比如ReentrantLock,另外加synchronized关键字也是悲观锁的一种方式。

    一般在面试过程中,我们会遇到HashMap与Hashtable的区别,其中会被问到的一个点就是,他们线程安全性如何?这里我们一般会知道Hashtable是线程安全的,因为它的方法是加了synchronized修饰的,也就是加了锁,所以在多线程情况下是线程安全的。同样的问题还有StringBuffer与StringBuilder的区别,StringBuffer方法是同步方法,也就是加了锁,所以是线程安全的,但是牺牲了性能,所以在效率上一般没有StringBuilder好。

    而乐观锁就是cas机制,内部采用compare与swap机制,常见的应用有AtomicInteger。

    悲观锁在mysql中,通过锁定行记录的方式。比如:

begin;
select * from xx for update;
//其他操作
commmit;

    乐观锁在mysql中,就是通过version字段来实现。增加数字类型的version字段。比如修改记录的时候:

update xx set name = 'aa' ,version=1 where version = 0;

    当多个线程对同一个记录做修改的时候,总有一个可以成功,因为一旦一个操作成功之后,version就+1,不再是原来的0。所以其他线程请求必然失败。 

以上是关于悲观锁与乐观锁以及如何用java语言和mysql实现的主要内容,如果未能解决你的问题,请参考以下文章

Java并发问题--乐观锁与悲观锁以及乐观锁的一种实现方式-CAS

Java并发问题--乐观锁与悲观锁以及乐观锁的一种实现方式-CAS

Java并发问题--乐观锁与悲观锁以及乐观锁的一种实现方式-CAS

MYSQL悲观锁与乐观锁

乐观锁与悲观锁

[初级]深入理解乐观锁与悲观锁