当前位置: 首页 > news >正文

8.15锁的优化

1.锁升级(锁膨胀)

无锁 -> 偏向锁 -> 轻量级锁 -> 重量级锁

偏向锁:不是真的加锁,而是做了一个标记,如果有别的线程来竞争才会真的加锁,如果没有别的线程竞争就不会加锁.

轻量级锁:一个线程占领锁资源后,另一个线程通过自旋的方式反复确认锁是否被是否(这个过程比较消耗CPU资源,但是可以快速获取锁资源).

重量级锁:随着竞争锁的线程越来越多,轻量级锁会升级成重量级锁,重量级锁等待的时间会更长.

2.锁消除

编译器会智能判断当前代码是否需要加锁,然后根据情况自动删除锁.

3.锁粗化

锁的粒度:加锁后,锁中的实际执行的代码越多,粒度越大,否则越小.

锁的粒度小,并发程度高,但是频繁地加锁和解锁有一定的开销.

锁的粒度大,加锁和解锁的次数少,资源开销少.

所以要根据具体情况定.

http://www.lryc.cn/news/111234.html

相关文章:

  • 单片机复位电路分析
  • 公文写作技巧:“三面镜子”写作提纲60例
  • useEffect中的函数会执行2次原因
  • 更新k8s环境支付系统支付证书
  • C#的yield
  • 外卖多门店小程序开源版开发
  • 打印图案、
  • # Windows 环境下载 Android 12源码
  • 【运维面试】Docker技术面试题总结
  • CNN成长路:从AlexNet到EfficientNet(01)
  • 使用IDEA操作Mysql数据库
  • ChatGPT下架官方检测工具,承认无法鉴别AI内容
  • Java通过实例调用getClass()方法、类名.class操作、通过运行时类获取其它信息
  • UE5+Paperzd问题
  • K8S系列文章之 自动化运维利器 Ansible
  • Julia 字典和集合
  • devops-发布vue前端项目
  • 使用正则表达式设置强密码
  • epoll、poll、select的原理和区别
  • 【学习笔记】Java安全之反序列化
  • 算法练习--leetcode 数组
  • 本地 shell无法连接centos 7 ?
  • C 语言的基本算术运算符 = + - * /
  • SQL注入实操三(SQLilabs Less41-50)
  • HOT77-买卖股票的最佳时机
  • CSS调色网有哪些
  • Day10-NodeJS和NPM配置
  • 线性代数 | 机器学习数学基础
  • Nios初体验之——Hello world!
  • [Linux]理解文件系统!动静态库详细制作使用!(缓冲区、inode、软硬链接、动静态库)