处理器上有一套完整的协议,来保证Cache一致性。比较经典的Cache一致性协议当属MESI协议,奔腾处理器有使用它,很多其他的处理器都是使用它的变种。
单核Cache中每个Cache line有2个标志:dirty和valid标志,它们很好的描述了Cache和Memory(内存)之间的数据关系(数据是否有效,数据是否被修改),而在多核处理器中,多个核会共享一些数据,MESI协议就包含了描述共享的状态。
在MESI协议中,每个Cache line有4个状态,可用2个bit表示,它们分别是:

M(Modified)和E(Exclusive)状态的Cache line,数据是独有的,不同点在于M状态的数据是dirty的(和内存的不一致),E状态的数据是clean的(和内存的一致)。(Shared)状态的Cache line,数据和其他Core的Cache共享。只有clean的数据才能被多个Cache共享。I(Invalid)表示这个Cache line无效。
E状态示例如下:

只有Core 0访问变量x,它的Cache line状态为E(Exclusive)。
S状态示例如下:

3个Core都访问变量x,它们对应的Cache line为S(Shared)状态。
M状态和I状态示例如下:

Core 0修改了x的值之后,这个Cache line变成了M(Modified)状态,其他Core对应的Cache line变成了I(Invalid)状态。
在MESI协议中,每个Cache的Cache控制器不仅知道自己的读写操作,而且也监听(snoop)其它Cache的读写操作。每个Cache line所处的状态根据本核和其它核的读写操作在4个状态间进行迁移。

在上图中,Local Read表示本内核读本Cache中的值,Local Write表示本内核写本Cache中的值,Remote Read表示其它内核读其它Cache中的值,Remote Write表示其它内核写其它Cache中的值,箭头表示本Cache line状态的迁移,环形箭头表示状态不变。

AMD的Opteron处理器使用从MESI中演化出的MOESI协议,O(Owned)是MESI中S和M的一个合体,表示本Cache line被修改,和内存中的数据不一致,不过其它的核可以有这份数据的拷贝,状态为S。

Intel的core i7处理器使用从MESI中演化出的MESIF协议,F(Forward)从Share中演化而来,一个Cache line如果是Forward状态,它可以把数据直接传给其它内核的Cache,而Share则不能。

0-并发编程-EMSI相关推荐

  1. Java 并发编程CAS、volatile、synchronized原理详解

    CAS(CompareAndSwap) 什么是CAS? 在Java中调用的是Unsafe的如下方法来CAS修改对象int属性的值(借助C来调用CPU底层指令实现的): /*** * @param o ...

  2. java虚拟机线程调优与底层原理分析_Java并发编程——多线程的底层原理

    " Java代码在编译后会变成Java字节码,字节码被类加载器加载到JVM里,JVM执行字节码,最终需要转化为汇编指令在CPU上执行,Java中所使用的并发机制依赖于JVM的实现和 CPU的 ...

  3. 并发编程之多进程编程(python版)

    目录 1 python多进程编程概述 2 需求和方案 背景: 需求: 解决思路: 需要解决的问题和方案: 3 完整代码 1 python多进程编程概述 python中的多线程无法利用多核优势,如果想要 ...

  4. JSR 133 Java内存模型以及并发编程的最权威论文汇总

    Java内存模型 先看官方文档: https://docs.oracle.com/javase/specs/ JSR 133:Java TM内存模型和线程规范修订版:https://www.jcp.o ...

  5. python并发编程方法_Python Futures并发编程详解

    无论哪门编程语言,并发编程都是一项很常用很重要的技巧.例如,爬虫就被广泛应用在工业界的各个领域,我们每天在各个网站.各个 App 上获取的新闻信息,很大一部分便是通过并发编程版的爬虫获得. 正确合理地 ...

  6. Python3 与 C# 并发编程之~ Net篇

    NetCore并发编程 示例代码:https://github.com/lotapp/BaseCode/tree/master/netcore/4_Concurrency 先简单说下概念(其实之前也有 ...

  7. Java并发编程71道面试题及答案

    Java并发编程71道面试题及答案 1.在java中守护线程和本地线程区别? java中的线程分为两种:守护线程(Daemon)和用户线程(User). 任何线程都可以设置为守护线程和用户线程,通过方 ...

  8. java高并发编程(二)

    马士兵java并发编程的代码,照抄过来,做个记录. 一.分析下面面试题 /*** 曾经的面试题:(淘宝?)* 实现一个容器,提供两个方法,add,size* 写两个线程,线程1添加10个元素到容器中, ...

  9. Java并发编程有多难?这几个核心技术你掌握了吗?

    本文主要内容索引 1.Java线程 2.线程模型 3.Java线程池 4.Future(各种Future) 5.Fork/Join框架 6.volatile 7.CAS(原子操作) 8.AQS(并发同 ...

  10. Python并发编程实例教程

    有关Python中的并发编程实例,主要是对Threading模块的应用,文中自定义了一个Threading类库. 一.简介 我们将一个正在运行的程序称为进程.每个进程都有它自己的系统状态,包含内存状态 ...

最新文章

  1. 区块链+能源,能擦出什么样的火花?
  2. 数据结构与算法:22 精选练习50
  3. 日本漫画巨匠力作,看漫画就能学会Python,简直不要太轻松
  4. Anaconda详细安装及安装Scrapy框架
  5. android loading封装_我们经常用的Loading动画居然还有这种姿势
  6. modelmap前端怎么取值_【百度】前端开发岗面试题
  7. Efficient Inference in Fully Connected CRFs with Gaussian Edge Potential
  8. windows 系统配置多网关win添加静态路由
  9. Oracle物化视图的一般使用【转】
  10. 计算机运行一段时间黑屏,电脑运行一段时间之后间歇性黑屏,黑屏一秒钟恢复,过几秒又黑屏,是显卡问题还是cpu问题...
  11. Leetcode NO.63 Unique Paths II
  12. Visio对一个对象进行水平翻转
  13. MAC帧经过路由器,源目标MAC地址会改变,但是IP的源,目的地址不会改变
  14. 姜烧猪肉+日式厚蛋烧+蚝油青笋
  15. 卷积神经网络学习项目--Kaggle仙人掌识别--基于TensorFlow(未完成)
  16. 自动控制的故事——数字控制部分
  17. maya! board_3D角色模型很难做?Maya、Zbrush人头建模终极秘笈
  18. 15款免费WiFi入侵破解安全测试工具
  19. SQLZOO练习答案(一):SELECT names/zh
  20. Linux快速查看文件内容中包含的字符

热门文章

  1. 胖人习惯的味道,同在肥胖中的你踩雷了吗?
  2. 谈恋爱已经不能满足我了,看了《独家记忆》想原地结婚
  3. python代码插入图片_jupyter notebook插入本地图片的实现
  4. 英安特1600说明书_英安特报警主机修改时间 英安特1600简易编程
  5. Javassist动态创建类
  6. YUV和RGB的相互转换实验
  7. python soap服务_python之SOAP服务—ZIPCodeWorldUSWebService
  8. 跨域以及跨域的小周边
  9. 全国职业院校技能大赛 网络建设与运维 赛题(二)【201题起】
  10. linux下安装sendEmail Timeout while connecting to smtp.exmail.qq.com:25