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

网站建设常州乐陵seo外包公司

网站建设常州,乐陵seo外包公司,企业设计网站公司排名,微信开发在哪能看今天和大家聊一聊伪共享 1.什么是伪共享? 缓存一致性协议在计算机中针对的最小单元:缓存行,每个缓存行的大小是64字节,一串连续的64字节数据都会存储到缓存行中。 假设数据A和数据B在同一缓存行中,CPU1修改了数据A&am…

今天和大家聊一聊伪共享

1.什么是伪共享?

缓存一致性协议在计算机中针对的最小单元:缓存行,每个缓存行的大小是64字节,一串连续的64字节数据都会存储到缓存行中。

  • 假设数据A和数据B在同一缓存行中,CPU1修改了数据A,根据缓存一致性协议,CPU1会通知其他CPU这一行的缓存数据已经失效。此时CPU2想要修改数据B,但是缓存行已经失效了,所以需要重新从主内存中读取数据,然后重新写会缓存行中。这样缓存的优势就完全没有了。
  • 上述问题就是伪共享的场景,如果同时有多个CPU同时修改同一缓存行的数据,频繁回写主内存,会大大降低性能。
    如下图所示:
    在这里插入图片描述
    在这里插入图片描述

2.如何解决伪共享问题?

  • 伪共享的根源就是不同的数据缓存到了同一缓存行中,如果我们能把独立的数据都单独存储到不同的缓存行,那么伪共享的问题也就不存在了。
  • 缓存行填充:
    当我们存储的数据不足64字节的时候,我们可以手动将余下的字节空间填充,以空间换时间的方式,解决伪共享。
    举个例子:
public class FalseShareTest  {public static void main(String[] args) throws InterruptedException {Rectangle rectangle = new Rectangle();long beginTime = System.currentTimeMillis();Thread thread1 = new Thread(() -> {for (int i = 0; i < 100000000; i++) {rectangle.a = rectangle.a + 1;}});Thread thread2 = new Thread(() -> {for (int i = 0; i < 100000000; i++) {rectangle.b = rectangle.b + 1;}});thread1.start();thread2.start();thread1.join();thread2.join();System.out.println("执行时间" + (System.currentTimeMillis() - beginTime));}
}class Rectangle {volatile long a;volatile long b;
}
//运行结果:
执行时间2815

一个long类型是8字节,我们在变量a和b之间不上7个long类型变量呢,输出结果是啥呢?如下:

class Rectangle {volatile long a;long a1,a2,a3,a4,a5,a6,a7;volatile long b;
}
//运行结果
执行时间1113

我们可以发现,利用填充数据的方式,可以让读写的变量分割到不同缓存行中,性能可以大大提高!

3.消除伪共享的框架应用

Disruptor是一个性能极强的开源的无锁并发框架,基于Disruptor的LMAX架构交易平台,号称单线程内每秒可处理600万笔订单。简直是一个不折不扣的性能小钢炮。
Disruptor框架的核心是它的Ringbuffer环形缓冲。这里不做框架的具体分析,有兴趣可在github下载源码。推荐大家阅读Disruptor框架。
在这里插入图片描述
在Disruptor中,也是应用了大量的缓存行填充,消除了伪共享的问题。

http://www.ds6.com.cn/news/106459.html

相关文章:

  • 农村创业好项目网站推广优化价格
  • 帮人做网站被徐州派出所抓百度的营销推广模式
  • 做俄语网站建设厦门seo排名优化方式
  • wordpress 媒体库不显示优化推广联盟
  • 网站建设风险管理计划书seo排名点击器原理
  • 网站根目录 设置北京环球影城每日客流怎么看
  • 网站的工作简报怎么做重庆seo优化公司
  • 人才网站的seo怎么做最新国内你新闻
  • 哪些网站是jsp做的一键优化大师下载
  • 做签名照的网站汽油价格最新调整最新消息
  • 浙江企业在线如何优化网页
  • 台州优化排名推广seo标题优化关键词怎么选
  • 龙华网站建设yihekj外国网站的浏览器
  • 网站改版工作方案网络营销的现状
  • 济南网站建设阝力荐聚搜网网络平台推广具体是怎么推广
  • 网站数据统计怎么做免费推广软件
  • 免费推广做产品的网站关键词推广计划
  • 旧电脑做网站服务器今日新闻最新事件
  • 优斗士做网站怎么样品牌全案策划
  • 成交型网站模板怎么制作网站教程手机
  • 网站广告位价格一般多少seo每日工作内容
  • 深圳 网站建设培训常见的关键词
  • java语言做网站开发网站空间
  • 程序员做交友网站360优化大师官方网站
  • 文做网站西安网站seo厂家
  • 北京手机网站制作多少钱长沙优化科技有限公司
  • 宿州网站建设费用怎么申请域名建立网站
  • 企业网站建设方案ppt品牌广告和效果广告的区别
  • 网页设计师都在什么网站上面找素材竞价托管信息
  • dede静态网站模板下载电商平台开发