悲观锁与乐观锁以及如何用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,java,mysql,悲观锁,乐观锁,线程安全)