这篇文章主要介绍“Java中的乐观锁和悲观锁简单介绍”,在日常操作中,相信很多人在Java中的乐观锁和悲观锁简单介绍问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Java中的乐观锁和悲观锁简单介绍”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
站在用户的角度思考问题,与客户深入沟通,找到融水网站设计与融水网站推广的解决方案,凭借多年的经验,让设计与互联网技术结合,创造个性化、用户体验好的作品,建站类型包括:成都做网站、网站建设、外贸营销网站建设、企业官网、英文网站、手机端网站、网站推广、主机域名、虚拟空间、企业邮箱。业务覆盖融水地区。
1、 分类一:乐观锁与悲观锁
a)悲观锁:认为其他线程会干扰本身线程操作,所以加锁
i.具体表现形式:synchronized关键字和lock实现类
b)乐观锁:认为没有其他线程会影响本身线程操作,所以不加锁
i.具体表现形式:java的原子类的递增操作
ii.原理:采用cas算法
c)Cas算法:交换与比较
i.涉及三个数:需要读写的内存值V,进行比较的值A,要写入的新值B
ii.具体操作:若A=V,就用B更新V,否则不进行任何操作
iii.会用ABA问题:cas算法需要判断内存值V是否发生变化,如果a值变成b值然后又变回a值,cas算法就会无法判断,产生错误。解决上问题:在变量前添加版本号,将aba变成1a2b3c
iv.循环时间长开销大,因为自旋需要消耗cpu
v.只能保证一个共享变量的原子操作
2、 分类二
a) 重入锁:支持重进入的锁,排它锁
3、 分类三
a)读写锁:一对锁,读锁,写锁,在同一时刻允许多线程访问
到此,关于“Java中的乐观锁和悲观锁简单介绍”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注创新互联网站,小编会继续努力为大家带来更多实用的文章!