赞
踩
本文假定你有一定的计算机组成原理和操作系统方面的知识,这里说的尽量简洁清晰一些,然后要再结合一个例子来具体走一下。
首先要明确,想要从内存中取数据要分两步:1.获得数据在内存的物理地址 2.从内存中取数据 可能乍一看觉得有点像废话,但是这两步必须很清楚,而且这两步涉及的过程差别很大,下面具体说一下。
如何获得数据的内存实地址? 这里我们首先就要把虚拟地址(逻辑地址)进行转化,我以请求分页管理为例,一般说来这里也分为两步:(1) 先查找TLB(快表:为硬件结构,保存有部分内存中页表的内容,目的是提高效率)我们先把给出虚拟地址写成二进制的形式,由页面大小得到页内偏移位数,剩下的是虚拟页号,在这里虚拟页号进一步分为TLB标记和TLB组索引。
由组索引和TLB标记查看有无对应的物理页号及标记位是否为”1”,若存在,把物理页号拼接页内地址得到实地址;若不存在,说明TLB不命中,进入下面一步(2)查找内存中的页表。这里就相对比较单纯了,通过页号及页表寄存器找到相应的页表项,看一下有没有物理页号及有效位是否为“1”,若有,则命中,把物理页号拼接到页内地址即得到实地址;若无,则比较麻烦了,说明内存中没有要找的这个页面,产生缺页中断,需从外存调入。第一部分大体就是如此,具体细节不多说,但是这个过程一定要很清晰!
接下来就是根据地址来访问数据,在开始之前,有必要先给出Cache的工作原理图(摘自课本),该图非常清晰动人,哈哈!
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
赞
踩
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。