文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

从 Java 锁到分布式锁

2024-12-02 15:46

关注

本文主要是在学习 Java 锁以及分布式锁的源码后,做出的归纳总结。

1锁的最基本要素

为什么要使用锁?

关于为什么要使用锁这个问题,答案显而易见:“为了避免多线程并发冲突”。

在多线程中对公共数据的修改,必须要保证只有线程在进行操作。这里的公共数据可以是公共变量,也可以是数据库中的一行数据。

锁的基本要素

知道为什么要加锁之后,就可以得出加锁的基本要素:

简单来说应该就是这些要素,遗漏之处,欢迎补充。

2加锁标志

加锁标志,就是需要一个标志来表示是否加锁成功,并且这个加锁标志要保证原子性。

3锁持有者

4锁重入

当获得锁的线程再次尝试获取锁的时候,保证需要计数。

5锁等待

  1. 刚开始是无锁的
  2. 偏向锁:一段同步代码一直被一个线程访问,这个线程自动获取锁,大多数都是由同一个线程获取锁,这就会出现偏向锁。目的是只有一个线程执行同步代码块时提高性能,JDK 6 后在 JVM 中默认开启。对象头标志位(01-无锁) 是否偏向锁标志(1-是偏向锁)
  3. 轻量级锁:锁是偏向锁时,被其他线程访问,偏向锁就升级为轻量级锁,其他线程通过自旋形式尝试获取锁 对象头标志位 00
  4. 重量级锁:只有一个线程等待,该线程是在自旋等待获取锁。当自旋一定次数或者一个持有锁一个自旋时来了第三个线程,就会升级为重量级锁。对象头标志位 10

6锁释放

7总结

本文从多个角度总结分析了锁和分布式锁的基本要素,同样基于 MySQL 等数据库的锁可以参考实现。

 本文转载自微信公众号「程序员小航」,可以通过以下二维码关注。转载本文请联系程序员小航公众号。

 

来源:程序员小航内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯