首页 > 其他分享 >关于锁

关于锁

时间:2022-12-07 20:34:59浏览次数:60  
标签:CAS 乐观 实现 线程 关于 悲观 情况

悲观锁和乐观锁(用于自己记忆,整理)

关于悲观和乐观锁原链接:看完你就应该能明白的悲观锁和乐观锁 (qq.com)

乐观锁和悲观锁是一种设计思想,乐观锁和悲观锁对于理解 Java 多线程和数据库来说至关重要。

 

悲观锁在持有数据的时候总会把资源 或者 数据 锁住,这样其他线程想要请求这个资源的时候就会阻塞,直到等到悲观锁把资源释放为止。传统的关系型数据库里边就用到了很多这种锁机制,比如行锁,表锁等,读锁,写锁等,都是在做操作之前先上锁。悲观锁的实现往往依靠数据库本身的锁功能实现。

Java 中的 Synchronized 和 ReentrantLock 等独占锁(排他锁)也是一种悲观锁思想的实现,因为 Synchronzied 和 ReetrantLock 不管是否持有资源,它都会尝试去加锁。

悲观锁因为对读写都加锁,所以它的性能比较低,对于现在互联网提倡的三高(高性能、高可用、高并发)来说,悲观锁的实现用的越来越少了,但是一般多读的情况下还是需要使用悲观锁的,因为虽然加锁的性能比较低,但是也阻止了像乐观锁一样,遇到写不一致的情况下一直重试的时间。

 

 

乐观锁读取不会上锁,但是乐观锁在进行写入操作的时候会判断当前数据是否被修改过。乐观锁的实现方案一般来说有两种:版本号机制 和 CAS(Compare-and-Swap,即比较并替换算法)实现 。乐观锁多适用于多读的应用类型,这样可以提高吞吐量。

 

在Java中java.util.concurrent.atomic包下面的原子变量类就是使用了乐观锁的一种实现方式CAS实现的。

乐观锁用于读多写少的情况,即很少发生冲突的场景,这样可以省去锁的开销,增加系统的吞吐量。

 

CAS 即 compare and swap(比较与交换),是一种有名的无锁算法。即不使用锁的情况下实现多线程之间的变量同步,也就是在没有线程被阻塞的情况下实现变量的同步,所以也叫非阻塞同步(Non-blocking Synchronization

CAS 中涉及三个要素:

  • 需要读写的内存值 V

  • 进行比较的值 A

  • 拟写入的新值 B

当且仅当预期值A和内存值V相同时,将内存值V修改为B,否则什么都不做。

 

乐观锁在进行写操作的时候会判断是否能够写入成功,如果写入不成功将触发等待 -> 重试机制,这种情况是一个自旋锁,简单来说就是适用于短期内获取不到,进行等待重试的锁,它不适用于长期获取不到锁的情况,另外,自旋循环对于性能开销比较大。

 

 CAS 适用于写比较少的情况下(多读场景,冲突一般较少),synchronized (同步的)适用于写比较多的情况下(多写场景,冲突一般较多)

  • 对于资源竞争较少(线程冲突较轻)的情况,使用 synchronized 同步锁进行线程阻塞和唤醒切换以及用户态内核态间的切换操作额外浪费消耗 cpu 资源;而 CAS 基于硬件实现,不需要进入内核,不需要切换线程,操作自旋几率较少,因此可以获得更高的性能。

  • 对于资源竞争严重(线程冲突严重)的情况,CAS 自旋的概率会比较大,从而浪费更多的 CPU 资源,效率低于 synchronized。

 

标签:CAS,乐观,实现,线程,关于,悲观,情况
From: https://www.cnblogs.com/sinoblog/p/16964429.html

相关文章

  • 关于架构师职责的最完美解答
    文章目录​​前言​​​​一、业务架构设计​​​​二、技术架构设计​​​​三、开发规划设计​​​​总结​​前言不想到将军的士兵不是好士兵,同样不想当架构师的程序员不......
  • 关于hashmap的负载因子
    也就是loadFactor这个属性,这个属性主要用在resize方法。在putVal的方法里:1.size=0的时候,就重新设置Map的大小2.加入对象后,size++>map的大小,则重新设置Map的大小重新设置Ma......
  • 关于MFC中resource.h头文件中宏的说明
    在写MFC程序时,当需要动态创建一些控件的时候,需要传递一个ID给相应的控件,比如创建一个按钮CButtonm_bnTestButton;m_bnTestButton.Create(_T("我的按钮"),WS_VISIBLE|WS_C......
  • 关于博客的一些想法
    在博客园上每天记随笔,总结每天学的知识然后达到一定程度后,将所学知识汇总为一篇文章,图片少就发到自己部署的博客上,图片多就在掘金发布,发布的文章在notion笔记中......
  • SLAM十四讲——关于李群与李代数的理解
    1、李代数的存在是为了更好地估计变换矩阵T。2、李群对乘法封闭。3、李代数是对加法封闭(因为其由向量组成)。4、李代数对应李群的正切空间,它描述了李群局部的导数。5、对于某......
  • 关于MultipartFile中transferTo方法使用记录
    最近在项目中使用springboot写了一个文件上传的功能,但是遇到了路径上传错误的问题,以下是正确代码示范:1@RequestMapping(value="/sc/uploadAcceptanceData",method=......
  • [转载]关于设计模式
    https://refactoringguru.cn/design-patterns稍作整理文末有彩蛋[转载]关于设计模式设计模式是什么设计模式是软件设计中常见问题的典型解决方案。它们就像能根据......
  • idea java 关于mysql数据库连接的相关步骤
    1.首先在你的项目中建立一个lib文件夹(表示加入依赖)(资源在上面)       2.选择这个项目的Properties在下面页面中添加Libraries进入这个项目jar配置到项......
  • 关于对接芝麻 GO 的几点问题
    前言:        芝麻GO是支付宝给商家提供的一款助力商家进行拉新,促进下单的营销工具。对于用户是先享权益,后承诺任务,只需要签约一份协议就能开始一个任务。  ......
  • 关于element中el-message信息提示内容想要换行的问题
    我今天遇到的问题是:后台给我输出了提示内容的字符串,用了element组件的message提示框,结果是一行显示的想要的效果是能够换行显示主要原因是前端代码没有解析\n,其实解决方......