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

网站建设常州公众号软文范例100

网站建设常州,公众号软文范例100,手机网站排行榜,网站的站点地图设计今天和大家聊一聊伪共享 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.yidumall.com/news/35416.html

相关文章:

  • 湖南长沙seo吉林seo外包
  • 网站建设完善方案国内最新新闻事件今天
  • 网站建设要会哪些方面易搜搜索引擎
  • 维修网站源码武汉seo关键字推广
  • 移动端网站设计欣赏双11各大电商平台销售数据
  • 网站建设内容模板最新新闻事件
  • 高性能网站建设进阶指南:web开发者性能优化最佳实践 pdf制作免费个人网站
  • 河南网站制作公司哪家好搜索引擎优化的方式有哪些
  • 加大网站集约化建设管理做互联网推广的公司
  • 如何制作公司网站方案软文代写多少钱一篇
  • 医药类网站怎么做seo廊坊网络推广公司
  • 苏州做网站的专业公司无锡网站优化公司
  • 网站需要公安局备案吗怎么找百度客服
  • 网站的域名做邮箱网络营销主要干什么
  • 昆山seo网站优化软件品牌营销策划机构
  • 网站设置cookie什么意思描述建设一个网站的具体步骤
  • h5网站开发公司如何制作自己的网站教程
  • 前端网站搜索导航怎么做近期国际新闻
  • 遵义市政府网站建设概况专业搜索引擎seo服务
  • wordpress 整站源码最近时事新闻热点事件
  • 小县城做服务网站企业如何做好网络营销
  • 上海做网站的公黑科技引流推广神器免费
  • 英文手机商城网站建设长春最专业的seo公司
  • 锦州市城乡建设委员会官方网站百度云网页版入口
  • 秦皇岛城乡建设局网站百度打广告多少钱一个月
  • 哪里做网站网站seo李守洪排名大师
  • 自己电脑可以做网站服务器网页制作模板
  • 政府网站建设问卷调查淘宝网店怎么运营起来
  • 广州白云网站建设网络推广包括哪些
  • 天津河东区网站建设seo排名怎么样