关于cache的计算方法

cache的命中率:
       在一个程序执行周期期间,设Nc表示 cache完成存储周期的总次数,Nm表示 主存完成存储的总次数,h定     义为命中率:
                                      h=Nc/(Nc+Nm)
   
cache的访问平均时间: 
       Tc表示 命中时的cache访问时间,Tm表示 未命中时的主存访问时间,1-h表示未命中率, 则cache/主存系     统的平均时间Ta为:
                                      Ta=h*Tc+(1-h)Tm
    
访问效率:
       设r=Tm/Tc 表示主存慢于cache的倍率, e表示访问效率,则有:
                                      e=Tc/Ta=Tc/(h*Tc+(1-h)*Tm)=1/(h+(1-h)*r)=1/(r+(1-r)*h)

    

根据引用\[1\]和引用\[2\]的内容,计算Cache的容量可以通过以下步骤进行: 1. 首先,确定主存块的大小和Cache行的大小是相等的。 2. 然后,将主存的总容量除以Cache行的大小,得到可以解读为多少个Cache的数据。 3. 将这个结果转换为二进制形式,可以得到高位的数目,即Cache的数目。 另外,根据引用\[3\]的内容,Cache的容量还可以通过计算Cache标记位数、数据位数和其他位数的和来得到。其中,Cache标记位数用于找到对应的主存块,数据位数对应主存中的数据,其他位数包括一些有效位和修改位等。 综上所述,计算Cache的容量可以根据主存块大小和Cache行大小相等的关系,或者通过计算Cache标记位数、数据位数和其他位数的和来得到。 #### 引用[.reference_title] - *1* [深入研读Cache存储的计算](https://blog.csdn.net/u011240016/article/details/52690297)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [[计算机组成原理,Cache总容量的计算方法]假设主存地址位数是32位,按字节编址,贮存和Cache采用全相联映射...](https://blog.csdn.net/getture/article/details/126407436)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值