- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我原本以为 MESI 等缓存一致性协议(protocol)可以提供伪原子性 但是 仅限个人 内存加载/存储 指示。如果我正在执行指令的获取、修改、写入组合,MESI 单独将无法在第一条指令到最后一条指令之间强制执行原子性。
但是,英特尔引用手册第 3a 卷的第 8 节说:
8.1.4 Effects of a LOCK Operation on Internal Processor Caches
For the P6 and more recent processor families, if the area of memory being locked during a LOCK operation is cached in the processor that is performing the LOCK operation as write-back memory and is completely contained in a cache line, the processor may not assert the LOCK# signal on the bus. Instead, it will modify the memory location internally and allow it’s cache coherency mechanism to ensure that the operation is carried out atomically. This operation is called “cache locking.” The cache coherency mechanism automatically prevents two or more processors that have cached the same area of memory from simultaneously modifying data in that area.
最佳答案
锁定作为一个概念与实际的总线#lock 信号之间存在差异——后者是实现第一个的手段之一。缓存锁定是另一种更简单、更高效的方法。
MESI 协议(protocol)保证如果一条线路由某个核心独占(无论是否修改),其他人都没有它。在这种情况下,您可以通过在缓存中添加简单的标志来自动执行多个操作,该标志会阻止外部窥探,直到操作完成。这将具有与锁定概念所规定的相同的效果,因为没有其他人可以更改甚至观察中间值。
在更复杂的情况下,该行不由单个缓存保存(例如,它可能在多个缓存之间共享,或者访问可能在两个缓存行之间拆分并且只有一个在您的缓存中 - 场景列表通常是实现CPU 制造商可能未披露具体信息)——在这种情况下,您可能不得不求助于像总线锁这样的“更重”的大炮,这通常可以保证没有人可以在共享总线上做任何事情。显然,这会对性能产生巨大影响,因此这可能仅在您别无选择时使用。在大多数情况下,一个简单的缓存级锁就足够了。请注意,像 Intel TSX 这样的新方案似乎以类似的方式工作,当您在缓存内工作时提供优化。
顺便说一句-您对单个指令的伪原子性的假设也是错误的-如果您提到单个内存操作(加载或存储),那将是正确的,因为一条指令可能包含多个( inc [addr]
例如不会在没有锁的情况下是原子的)。您的报价中也出现的另一个限制是访问需要包含在缓存行中-即使在单个加载或存储中,拆分行也不能保证原子性(因为它们通常被实现为 2 个内存操作,这些操作后来被合并)。
关于multithreading - CPU 什么时候可以忽略 LOCK 前缀并使用缓存一致性?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25476662/
GhostScript PDF/A 生成好像有错误 当您通过 GhostScript 生成 PDF/A 文档时,当您单击 Adobe Reader 时,会出现一个一致性选项卡,其中显示: “一致性
我有一个需要测试的 XPath 引擎实现。 是否有一组标准的一致性测试可以用来验证是否符合 XPath 规范(与 XSLT 相关)。 什么将是完美的 XML 文档 XPath 表达式和预期的结果。 最
帮助我了解在这种情况下我可以期望与 MongoDB 的一致性级别。 我们正在运行一个副本集,其中 Mongoid 中的 consistency 标志设置为 strong,这意味着只读到 master。
假设我有一个采用一个参数的方法。 此参数应满足以下要求: 'of type':方法需要知道参数属于特定类(或子类)。 'implements interface':方法需要知道参数实现了特定的接口(i
当协议(protocol)将属性声明为可选而具体类型将其声明为非可选时,如何使具体类型符合协议(protocol)? 这是问题所在: protocol Track { var trackNum
我正在考虑使用浏览器的 navigator.mimeTypes 数组作为第三级用户/浏览器标识符。例如,当我在 Chrome 上运行时... console.log(navigator.mimeTyp
我有以下协议(protocol): protocol ProtoAInput { func funcA() } protocol ProtoA { var input: ProtoAI
如果选择“最终”一致性,则发生写入的区域内的一致性是什么? 如果我只需要区域强一致性,应该选择哪个选项? 最佳答案 如果您需要在主要区域内进行强读取,则应该选择强一致性或有界过时一致性。 关于azur
您好,我是一名初学者,目前正在尝试学习 java 编程。课本上的问题: 编写一个程序来帮助人们决定是否购买混合动力汽车。你的程序的输入应该是:•新车的成本•预计每年行驶里程•预计汽油价格 •每加仑英里
我正在尝试制作一个可以在 UILabel 上使用的 Swift 协议(protocol), UITextField , 和 UITextView包含他们的text , attributedText ,
我有一个类扩展: extension UICollectionViewCell { class func registerFromNibInCollectionView(collectionV
为了在 Swift 中模拟对象进行测试,我通常遵循这样的模式:编写一个协议(protocol)来描述我想要的对象的行为,然后使用 Cuckoo 为其生成模拟以进行测试。 通常,这些协议(protoco
假设我有两个非通用协议(protocol)(1) protocol StringValue { var asString: String {get} } protocol StringProv
我有一组协议(protocol)可以在 UITableView 中显示一个元素: protocol TableRepresentableRow { var title: String { get
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
用“class”标记 CacheManager 解决了我的问题。 案例:一个简单的缓存器,mutating get 不是我想要的,那么对于引用类型或类类型应该怎么做? protocol Cacher
我想要一个符合协议(protocol)的变量,但是 swift 编译器告诉我协议(protocol)没有确认。 protocol A {} protocol B { var a : A { g
如果我有一个类 Christmas 和一个协议(protocol) Merry,要使 Christmas 符合 Merry,很多人会这样做: class Christmas { ... } e
@objc public protocol P1 { func p1foo() } @objc public protocol P2 { func p2foo() } class A: NSO
我有一些结构符合的基本协议(protocol)(模型)。它们也符合 Hashable protocol Model {} struct Contact: Model, Hashable { v
我是一名优秀的程序员,十分优秀!