Java-伪共享

news2025/1/13 10:21:17

在说这个计算机术语之前,我先在这里问候所有问“什么是JVM伪共享”的垃圾JAVA程序员以及一瓶不满半瓶晃荡的面试官全家

我从来没想过国内已经很卷的JAVA圈,已经卷到语无伦次的地步了,“伪共享”是java程序员应该知道的吗?能问出这个问题的人,除了炫技(不知道从哪个网站得知的概念),这就好比我问一个UI,photoshop是如何实现的一样,在我看来,他会觉得我很NB,但是在他的眼中,我和SB有什么区别

吐槽完毕,伪共享,指的是一种现象,如果出现了这种现象,那就叫做伪共享,我以mysql的一个表做示例,相信你很快明白,下面是一个很简单的数据库表
在这里插入图片描述

假设现在我开启2个事务
事务1:修改id=1这条数据的name
事务2:修改id=1这条数据的age

如果我们不知道锁的颗粒度为行锁的情况下,我们会以为:
虽然是同一行,但是字段不同,事务1和事务2完全不冲突,那么它们应该并发的进行修改

很明显,我们上述的想法(以为)是错误的,虽然name和age是不同的字段,但是它们是一行数据,由于锁的最小粒度是行级,所以,要么事务1执行完之后,再执行事务2,或者事务2执行之后再执行事务1,总之,它俩不会一起执行,总要有个先后

我们上述的想法中的现象,就是伪共享,也就是“事务1和事务2完全不冲突”这个现象,就是伪共享,说白了就是这句话是错误的,我们以为可以同时修改,但是他们不会同时修改,这种现象,就是伪共享

伪共享现象的存在,导致可以运行的更快的程序,无法运行的更快,下面的方式可以解决伪共享,对于本例来说
建立2个表,一个name表,专门存name,一个age表,专门存age,这样的话事务1和事务2相互之间没有冲突

文章到此为止,你应该知道什么叫做伪共享,以及如何解决伪共享,下面说一个新的概念:cacheline
CPU与内存之间速度有巨大差异,为了减少这个差异,在CPU和内存之间,会有多个叫cacheline的缓存,多核CPU,多个核共享cacheline

将上述的伪共享例子带入实际情况,如下:
1:上述示例中的【数据库表】,指的就是cacheline
2:上述示例中的【事务1】和【事务2】,指的是多核CPU的多个核
3:上述示例中的name和age指的是内存中的数据

假设CPU有2个核,分别是核1和核2,并且按照如下先后顺序执行,此处涉及到局部性原理,不过问题不大
1:核1读取name数据,先判断的cacheline中是否有name,发现没有,则去内存中读取name,因为我们定义变量的时候,name和age是挨着的,所以顺便也把age读出来了(局部性原理),然后将name和age放到cacheline X中
2:核2读取age数据,先判断cacheline中是否有age,发现cacheline X中存在age(核1顺手带过来的),此时则不会再去内存中读取
此时,核1修改cacheline X中的name,并且再修改的过程中,核2修改的cacheline X中的age,这个时候,伪共享现象出现,因为CPU为了保证数据一致,一个核修改一个cacheline的时候,其他核心是不允许修改这个cacheline的

解决伪共享:核1读取name的时候,不要顺手把age放到cacheline X中,但是考虑到局部性原理,读取是成块操作的,只有一个办法,那就是让name和age分开,读取name的时候,name附近的那块数据里没有age即可,这样的话核1读取name的时候,会把name缓存到cacheline X中,当核2读取age的时候,很大可能将age缓存到cachelien Y中,这样,name和age就不在一个cacheline中了,之后核1与核2可并发修改name和age

如何将name和age分开:非常简单,将name和age两个属性分开,中间使用其他属性,例如sex什么的即可,或者,name和age两个属性不必分开,但是要保持足够宽,为了保证足够宽,可将name后面用0填充,或者在age前面用0填充内存,确保它俩占用两个cacheline

Java使用的是0填充的方式,以空间换取速度,在java中,0填充使用的是long类型,不过无所谓,主要目的就是0填充

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1366815.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Linux Shell】5. 运算符

文章目录 【 1. expr 命令 】【 2. 算术运算符 】【 3. 关系运算符 】【 4. 布尔运算符 】【 5. 逻辑运算符 】【 6. 字符串运算符 】【 7. 文件测试运算符 】 【 1. expr 命令 】 原生 bash 不支持简单的数学运算,但是可以通过其他命令来实现,例如 awk …

基于SSM图书管理系统【源码】【最详细运行文档】

SSM图书管理系统【源码】【最详细运行文档】 系统简介系统涉及系统运行系统演示源码获取 系统简介 以往的图书馆管理事务处理主要使用的是传统的人工管理方式,这种管理方式存在着管理效率低、操作流程繁琐、保密性差等缺点,长期的人工管理模式会产生大量…

超维空间M1无人机使用说明书——52、ROS无人机二维码识别与降落

引言:使用二维码引导无人机实现精准降落,首先需要实现对二维码的识别和定位,可以参考博客的二维码识别和定位内容。本小节主要是通过获取拿到的二维码位置,控制无人机全向的移动和降落,分为两种,一种是无人…

【JAVA】final、finally、finalize 有什么区别?

🍎个人博客:个人主页 🏆个人专栏: JAVA ⛳️ 功不唐捐,玉汝于成 目录 前言 正文 final: finally: finalize: 结语 我的其他博客 前言 在Java中,final、f…

适合培训协会搭建的培训机构管理系统开发方案

一、项目背景与目标 (一)项目背景 培训学校教务管理系统是培训机构数字化管理的必备系统,该系统功能大大提升机构办学的管理效率、提升机构在家长心中的专业度,市面上的培训机构管理系统收费越来越贵,为了给协会内培…

CMake入门教程【核心篇】静态库 (.a, .lib)

😈「CSDN主页」:传送门 😈「Bilibil首页」:传送门 😈「动动你的小手」:点赞👍收藏⭐️评论📝 文章目录 概述创建静态库添加静态库到你的项目完整代码示例实战使用技巧与注意事项总结与分析概述 静态库在C++开发中扮演着重要的角色。它们通常以.a(在Unix-like系统

django websocket实现聊天室功能

注意事项channel版本 django2.x 需要匹配安装 channels 2 django3.x 需要匹配安装 channels 3 Django3.2.4 channels3.0.3 Django3.2.* channels3.0.2 Django4.2 channles3.0.5 是因为最新版channels默认不带daphne服务器 直接用命令 python manage.py runsever 默认运行的是w…

python协程asyncio的应用,async,await,loop

关于协程,asyncio,async,await,loop的概念,参照上一篇文章可迭代对象,迭代器,生成器,协程-CSDN博客 上一章我们详细的讲解了上述各个名词的概念,但是这些东西实际上该怎…

Dash+Plotly | Web应用开发(1)

本文为https://github.com/CNFeffery/DataScienceStudyNotes的学习笔记,部分源码来源于此仓库。 本期内容主要为基础概念、web布局方法和交互回调。 文章目录 Dash的主要模块Highlightlayoutcallback 惰性交互阻止初次回调忽略回调匹配错误控制部分回调输出不更新获…

计算机毕业设计----SSM场地预订管理系统

项目介绍 本项目分为前后台,前台为普通用户登录,后台为管理员登录; 用户角色包含以下功能: 按分类查看场地,用户登录,查看网站公告,按分类查看器材,查看商品详情,加入购物车,提交订单,查看订单,修改个人信息等功能。 管理员角…

linux安装codeserver实现云端开发

先看图 下载安装包 https://github.com/coder/code-server/releases 找到code-server-版本号-linux-amd64.tar.gz,我这里是code-server-4.16.1-linux-amd64.tar.gz 1、使用acrm用户登录目标服务器 2、切换root用户,创建 vscode 用户,并设…

selenium对于页面改变的定位元素处理办法

在学习selenimu中,总是发现元素定位不到,想了各种办法,最后总结大致有两个原因。 1.等待时间不够,页面还没有完全渲染就进行操作,使用time模块进行等待。 2.换了页面后,发现定位不到元素,因为…

外包做了1个月,技术退步一大半了。。。

先说一下自己的情况,本科生,20年通过校招进入深圳某软件公司,干了接近4年的功能测试,今年年初,感觉自己不能够在这样下去了,长时间呆在一个舒适的环境会让一个人堕落!而我已经在一个企业干了四年的功能测试…

新颖度爆表。网络药理学+PPI+分子对接+实验验证

今天给同学们分享一篇生信文章“The convergent application of metabolites from Avena sativa and gut microbiota to ameliorate non-alcoholic fatty liver disease: a network pharmacology study”,这篇文章发表在J Transl Med期刊上,影响因子为7.…

LeetCode-58/709

1.最后一个单词的长度(58) 题目描述: 给你一个字符串 s,由若干单词组成,单词前后用一些空格字符隔开。返回字符串中 最后一个 单词的长度。 单词 是指仅由字母组成、不包含任何空格字符的最大子字符串。 思路&…

如何创建容器搭建节点

1.注册Discord账号 https://discord.com/这是登录网址: https://discord.com/ 2.点击startnow注册,用discord注册或者邮箱注册都可,然后登录tickhosting Tick Hosting这是登录网址:Tick Hosting 3.创建servers 4.点击你创建的servers,按照图中步骤进行

Android性能优化系列——内存优化

内存,是Android应用的生命线,一旦在内存上出现问题,轻者内存泄漏造成App卡顿,重者直接crash,因此一个应用保持健壮,要做好内存的使用和优化。网上有很多讲JAVA内存虚拟机的好文章,我就不赘述了。…

嵌入式-C语言-江科大-指针的详解与应用

文章目录 一:计算机存储机制二:定义指针三:指针的操作四:数组与指针五:指针的应用道友:最清晰的脚印,踩在最泥泞的道路上。 推荐视频配合我的笔记使用 [C语言] 指针的详解与应用-理论结合实践&a…

2024年了,难道还不会使用谷歌DevTools么?

我相信您一定对Chrome浏览器非常熟悉,因为它是前端开发者最亲密的伙伴。我们可以使用它查看网络请求、分析网页性能以及调试最新的JavaScript功能。 除此之外,它还提供了许多功能强大但不常见的功能,这些功能可以大大提高我们的开发效率。 让我们来看看。 1. 重新发送XHR…

网络流量分析与故障分析

1.网络流量实时分析 网络监控 也snmp协议 交换机和服务器打开 snmp就ok了 MRTG或者是prgt 用于对网络流量进行实时监测,可以及时了解服务器和交换机的流量,防止因流量过大而导致服务器瘫痪或网络拥塞。 原理 通过snmp监控 是一个…