从品牌网站建设到网络营销策划,从策略到执行的一站式服务
本篇内容介绍了“Java中cache line的状态有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
网站建设哪家好,找创新互联!专注于网页设计、网站建设、微信开发、小程序开发、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了曲沃免费建站欢迎大家使用!
cache line的状态:
1、状态M表示该缓存行中数据有修改,并且与内存中的数据不一致;
2、状态E表示该缓存行中数据有修改,并且与内存中的数据一致;
3、状态S表示该缓存行中数据与内存中的数据一致,并且与其它内核中的cache line一致;
4、状态I表示该缓存行无效;
每个cache控制器除了监听自己cache的读写操作还监听其它cache的读写操作与状态,因此每个缓存行根据当前所处的状态与监听的动作进行状态转换,简称MESI一致性协议。读写操作具体可分成4种类型(LR-本内核读取本cache,LW-本内核写本cache,RR-其它内核读其对应的cache,RW-其它内核写其对应的cache)状态转换过程如下:
1、当数据所在cache line处于I状态并发生LR时,如果其它内核cache line中没有该数据则从内存加载,然后该cache line状态变成E;如果其它内核cache line中有该数据并处于状态M时,令其写入到内存后然后本内核从内存中加载,两个cache line都处于S状态;如果其它内核cache line中有该数据且已处于状态S或者E时,本cache line从内存中加载然后都变成S状态。
当数据所在cache line处于I状态并发生LW时,先从内存加载数据然后在cache line中修改,状态变成M;如果其它内核cache line中有该数据,且状态为M时先令其更新到内存然后状态置为I;如果其它内核cache line中有该数据,且状态为E时将状态置为无效I。而本内核的cache line状态一直是M。
当数据所在cache line处于I状态并监听到RR和RW时不会作任何反应。
2、当数据所在cache line处于M状态并发生LR时,直接读取,状态不变。
发生LW时,直接写入,状态不变。
监听到RR时,数据会写入内存然后状态变成S。
监听到RW时,将数据写入内存便于其它内存读取最新数据,然后状态置无效I。
3、当数据所在cache line处于E状态并发生LR时,直接读取,状态不变。
发生LW时,直接写入,状态变成M。
监听到RR时,状态变成S。
监听到RW时,状态置无效I。
4、当数据所在cache line处于S状态并发生LR时,直接读取,状态不变。
发生LW时,修改cache line中的内容并将状态变成M,其余内核的cache line置无效状态I。
监听到RR时,状态不变。
监听到RW时,cache line置无效状态I。
“Java中cache line的状态有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注创新互联网站,小编将为大家输出更多高质量的实用文章!
成都网站建设公司地址:成都市青羊区太升南路288号锦天国际A座10层 建设咨询028-86922220
成都快上网科技有限公司-四川网站建设设计公司 | 蜀ICP备19037934号 Copyright 2020,ALL Rights Reserved cdkjz.cn | 成都网站建设 | © Copyright 2020版权所有.
专家团队为您提供成都网站建设,成都网站设计,成都品牌网站设计,成都营销型网站制作等服务,成都建网站就找快上网! | 成都网站建设哪家好? | 网站建设地图