什么是MESI缓存一致性协议?怎么解决并发的可见性问题?

什么是MESI协议?

MESI协议也叫做缓存一致性协议,主要是用来进行协调多核CPU的高级缓存的数据一致的。

MESI协议的四种状态?

MESI一致性协议定义了高速缓存中数据的4中状态,分别是:

M(Modified): 该缓存行有效, 数据被修改了,但未同步回内存。即数据只存在于本缓存行中,和内存中的数据不一样。

E(Exclusive): 该缓存行有效,数据未被修改,和内存中的数据一致,并且数据只存在本缓存行中。

S(Share):该缓存行有效,数据未被修改,和内存中的数据一致,并且数据同时存在于其他缓存中。

I(Invalid):该缓存行数据无效,数据已过时。

MESI如何解决多核CPU高速缓存数据一致?

JAVA内存模型底层其实也还是通过MESI一致性来使得一个线程修改了数据,把别的线程的工作内存副本数据弄失效的。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值