数据处理方法和装置的利记博彩app

文档序号:6615523阅读:208来源:国知局
专利名称:数据处理方法和装置的利记博彩app
技术领域
本发明涉及一种数据处理方法和装置,尤其涉及一种利用高速緩存技术 处理数据的方法以及装置。
背景技术
高速緩存技术是基于程序访问的局部性(locality)原理产生的。所谓 程序访问的局部性体现在两方面l)时间局部性,即如果一个单元^皮访问, 那么这个单元将来会被再次访问;2)空间局部性,即如果一个单元被访问, 那么与这个单元邻近的单元将会被访问。
如图1所示为现有技术采用高速緩冲器(以下称Cache)的系统结构示 意图,在CPU 1与主存储器2之间设置一个高速的、容量相对较小的存储器, 将当前正在访问的、以及其邻近的指令和数据存储在其中,以便CPU 1在将 来可以快速地访问使用,该存储器即为Cache 3。高速緩存技术极大地緩解 了 CPU与主存储器之间的数据传输瓶颈,在各种处理器中被普遍采用。
Cache緩存主存储器中数据的常见方式是将主存储器空间与Cache空 间相应地被划分成一系列的块(block),其中緩存块也称为緩存行,緩存块 的存储空间大小通常为32字节或64字节,主存块的存储空间大小通常大于 緩存块, 一般为64字节或128字节。主存储器中的主存块映射到高速緩存器 中的放置策略主要有3种全相联、直接映射和组相联。其中,全相联即将 一个主存块顺序读取至高速緩存器的所有緩存块中,例如一个主存块的大小 为64字节, 一个緩存块的大小为32字节,则主存块从緩存块的起始位置开 始,顺序存储占用两个緩存块,存储完一个主存块的内容后再重复存储该主
存块的内容,这种方式的优点是Cache的沖突小,缺点是速度慢;直接映射, 即将一个主存块按照设定规则读取至高速缓存器的一个緩存块中,该规则 可以为关联到的緩存块号-主存块号mod緩存块数,若一个緩存块不足以放 置一个完整的主存块时,则仅放置主存块前面的数据,填满一个緩存块为止, 直接映射方式的优点是速度快,缺点是緩存沖突大;组相联介于全相联和直 接映射之间,将緩存块分成若干组(Set),每个主存块采用直接映射方式被 读取到一个组中,其中緩存组号=主存块号mod緩存组数,然后在组内采用 全相联方式顺序放置在緩存块中,当该组内的緩存块不足以放置一个主存块 时,则仅放置主存块前面的数据,组相联的优缺点介于全相联和直接映射方 式之间。组相联通常可分为2路、4路和8路的组相联,路数即每个缓存组 内所具有的緩存块数,则直接映射可看作是单路组相联、全相联可看作是路 数为緩存块数的组相联。
如图2A所示为一个现有技术中的一个主存储器,每个主存块的大小为 64字节,待緩存的主存块号为"12",图2B~2E分别为该主存块在具有8 块緩存块,每个緩存块的大小为32字节的高速緩存器中映射情况的示意图。 图2B为采用全相联方式将该主存块顺序缓存在8个緩存块中,图2C为采用 直接映射方式緩存在高速緩存器中的第"4"号緩存块中,緩存规则为緩存块 号=主存块号mod緩存块数,即12mod8 = 4,图2D为采用2路组相联方式緩 存在高速緩存器第"0"组的所有緩存块中,设置在第"0"组是按照12mod4 -O的预设规则,图2E为采用4路组相联方式緩存在高速緩存器第"0"组 (12mod4 = 0)的所有緩存块中。
按照上述Cache緩存数据的方式,在基于高速緩存技术进行数据读取时 的基本方法为数据处理器,例如CPU在读取所需数据时,可以采用存储器 直4妄访问(Direct Memory Access,以下简称DMA)—技术读取,首先会读取 高速緩存器,当高速緩存器中未存储所需读取的数据时,会将所需数据所在 的主存块从主存储器中按照设定的方式读取至高速緩存器的緩存块中,通常所需数据是包含在一个独立使用的数据条目中的, 一个数据条目的大小往往 不相等,顺序存储在一个或多个主存块中,所以一般需要同时读取多个主存 块到緩存中,而后再从緩存块中读取至数据处理器。在基于高速缓存技术进 行数据读取的过程中,命中率是衡量緩存效率的主要指标。当高速緩存器中 緩存的数据不被命中时,就需要进行将数据换入、换出高速緩存器的操作, 这类操作的开销很大。因此,提高高速緩存器的命中率是提高效率,减少开 销的关键手段。
在数据读取过程中,发生不命中现象的原因主要有3种l)首次访问, 即高速緩存器中没有这个数据,必须从主存储器中读取,首次访问所造成的 冲突是不可避免的;2)容量不足,即因为高速緩存器容量太小而不能保存需 要访问的数据,数据换出后又被取入,高速緩存器的容量是由硬件决定的, 因此也难以避免;3)冲突,组相联或直接映射方式中,主存储器中映射到同 一组内的主存块数过多,导致某些主存块被反复的读入和换出,緩存沖突是 和主存块的组织结构,及其与緩存块的映射关系有关的,是目前为提高緩存 命中率而主要针对的研究对象。
在数据访问技术中,緩存冲突是一普遍现象,因为现有数据表的设计通 常不对表中的数据排放进行严格的要求,在少数情况下,仅根据编译器或CPU 的特点作字节对齐,表中数据的内容根据其功能来决定,表中数据的顺序一 般按照规范格式甚至没有规范而简单的排放。上述技术方案导致在访问数据 过程中会出现大量緩存冲突,增加了系统开销,降低了运行速度。

发明内容
本发明的目的是提供一种数据处理方法和装置,以实现在采用高速緩存 技术读取数据时,降低高速緩存冲突,减少系统开销,提高运行速度,以及 改善系统的性能。
为实现上述目的, 一方面,提供了一种数据处理方法,包括
设置用于存储数据子表的主存储器以组相联方式与高速緩存器相互关 联,主存储器包括数个存储空间相等、顺序排列的主存块,高速緩存器包括 数个存储空间相等、顺序排列的緩存块,且主存块存储空间为緩存块存储空间的两4咅或两4咅以上;
将两个或两个以上、由数个数据条目组成的数据子表顺序存储在主存储 器的主存块中;
调整数据子表的大小等于主存块存储空间大小的N倍,其中N为自然数, 且N"。
为实现上述目的,另一方面,提供了一种数据处理装置,包括
第一模块,用于设置用于存储数据子表的主存储器以组相联方式与高速 緩存器相互关联,主存储器包括数个存储空间相等、顺序排列的主存块,高 速緩存器包括数个存储空间相等、顺序排列的緩存块,且主存块存储空间为 緩存块存储空间的两倍或两倍以上;
第二模块,用于将两个或两个以上、由数个数据条目组成的数据子表顺 序存储在主存储器的主存块中;
第三模块,用于在存储数据子表最后一个数据条目的主存块中,设置用 于维持主存块存储一个数据子表中数据的空白条目。
本发明的数据处理方法可以采用本发明数据处理装置来执行。由以上技 术方案可知,本发明采用合理处理主存储器中数据表的技术手段,克服了现 有技术中,因数据表组织方式不当,导致緩存冲突高,数据访问命中率低, 从而读取速度低,系统性能差的技术问题。因此,本发明的技术方案能够有 效减少采用高速緩存技术访问读取数据过程中出现的緩存冲突现象,以提高 数据读取的速度,节省系统开销,改善系统的性能。
下面通过具体实施例并结合附图对本发明做进一步的详细描述。


图1所示为现有技术中采用高速緩存技术进行数据访问的系统结构示意图2A所示为现有技术主存储器中的数据分布图2B所示为图2A中主存储器按照全相联方式与高速缓存器间的映射关 系示意图2C所示为图2A中主存储器按照直接映射方式与高速緩存器间的映射 关系示意图2D所示为图2A中主存储器按照2路组相联方式与高速緩存器间的映 射关系示意图2E所示为图2A中主存储器按照4路组相联方式与高速缓存器间的映 射关系示意图3所示为本发明数据处理方法具体实施例的流程图4所示为本发明数据处理方法具体实施例中主存储器按照2路组相联方式与高速緩存器间的映射关系示意图5所示为本发明数据处理装置具体实施例的结构示意图。
具体实施例方式
数据处理方法实施例
本发明数据处理方法具体实施例是具体应用于防火墙系统中。防火墙是 位于网络边界的一种网络安全设备,它对进出网络的数据包进行安全检查。 目前绝大多数的防火墙都是有状态的,所谓状态是指连接的状态。防火墙在 其内部维护了一张规模较大的数据表,用于记录、跟踪连接的状态,所谓连 接状态可以是指IP层协议的连接状态,例如TCP连接状态中初始连接、连接 建立成功等等。连接状态表是状态防火墙的核心数据结构,该连接状态数据 表通常具有以下特点
(l)数据条目数量巨大,根据防火墙档次的不同,防火墙支持的并发连接数通常在几十万甚至几百万,因此防火墙需要维护的连接状态数量表中的
条目数量是巨大的;
(2 )访问非常频繁,防火墙每收到一个报文都要在连接状态数据表中进 行匹配查找、状态更新、统计等操作;
(3) 每个数据条目的信息元素很多,通常超过l个緩存块的大小,需要 记录的连接状态信息根据检测的深度不同而不同,其通常可包括识别此连 接的5元组,包含源地址、目的地址、协议、源端口和目的端口;识别此连 接当前协议状态,包括TCP状态、UDP/ICMP伪状态;TCP顺序号,例如发送 序号、确认序号;TCP当前窗口,应用层的有关信息,如FTP命令序列等; 各连接之间的相关信息;连接的活动情况;连接的超时;收发的流量统计; 数据流重组;以及各种特定业务的相关信息,如安全策略信息、路由信息等;
(4) 对信息元素访问的频率不同,有的需要频繁访问,有的很少访问。
外部的数据处理器,如CPU,对该连接状态数据表的访问速度是决定防
火墙性能的关键之一,本实施例基于高速緩存技术对该存储在主存储器中的 连接状态数据表进行数据处理的流程如图3所示,包括如下步骤
步骤101、设置用于存储数据子表的主存储器以组相联方式与高速緩存 器相互关联,该主存储器包括数个存储空间相等、顺序排列的主存块,该高 速緩存器包括数个存储空间相等、顺序排列的緩存块,且该主存块存储空间 为该緩存块存储空间的两倍或两倍以上;
步骤102、将两个或两个以上、由数个数据条目组成的数据子表顺序存 储在主存储器的主存块中;
步骤103、调整所述数据子表的大小等于所述主存块存储空间大小的N 倍,其中N为自然数,且N》2。
在步骤103之后,还可以进一步包括
步骤104、从高速緩存器读取数据,当高速緩存器中不存在所需数据时, 从与高速緩存器相关联的主存储器中,将所需数据所在主存块中的所有数据 按照设定规则,读取至高速緩存器的緩存块中;
步骤105、从緩存块中读取所需数据。
本实施例的技术方案,该主存储器的存储空间被划分为数个主存块,按 照组相联的方式分别与高速緩存器中的各緩存块相关联。该数据处理方法中 的步骤101、 102和103具体是在主存储器所连接的控制模块的控制下,将连 接状态数据表存储在主存储器的主存块中的,该控制模块可以为具有检测、 分析、处理数据功能的功能部件,或者为能够执行模糊控制的数据分析系统 等,该控制模块可以是与主存储器独立设置,相互连接的模块,也可以是与 主存储器集成在一起形成主存储装置,其执行的具体操作步骤为
在步骤101中,首先,设置用于存储数据子表的主存储器以组相联方式 与高速緩存器相互关联,例如2路、4路……Y路组相联。在此步骤中,将主 存储器划分为数个存储空间相等、顺序排列的主存块,将高速緩存器划分为 数个存储空间相等、顺序排列的緩存块,且设置主存块存储空间为緩存块存 储空间的两倍或两倍以上,例如设置緩存块为32字节时,设置主存块为64 字节或128字节等,设置完成的主存块用于存储数据子表,数据子表是数据 表的一部分,以防火墙的连接状态表为例,数据子表就是其中的一个连接状 态子表,每个数据子表存储的数据格式基本相同,例如都用于存储一个连接 状态的5元组,包括源地址、目的地址、协议、源端口和目的端口,而数据 子表中每个具有独立意义和作用的数据又形成数据条目,例如"源地址"就 是一个数据条目,数据条目所占用的空间大小可以并不一致。
在上述步骤102中,将多个数据子表顺次且连续地存储至主存储器的主 存块中。
在上述步骤103中,调整数据子表的大小等于主存块存储空间大小的N 倍,其中N为自然数,且N≥2。其具体的调整方式是在存储数据子表最后一 个数据条目的主存块中设置空白条目,使该主存块至多存储一个数据子表中 的数据,避免出现有些主存块存储两个数据子表中的数据,而第二个数据子 表后半部分的数据要存储到下一个主存块的现象。因为一个数据子表的换出 导致一个主存块被换出时,会有两个以上数据子表的部分内容被换出覆盖,
若需要读取这部分数据时,又要整体的进行一次从主存储器到高速緩存器的 读取,这无疑增加了系统的开销。设置空白条目的具体方式可以是当主存块 中已经存储有一个数据子表的数据,该数据子表之后还有空余存储空间可存 储下一个数据子表时,则在该空余存储空间内设置空白条目来占据该存储空 间。
本实施例的技术方案实现了主存块不同时存储两个数据子表的数据,即 通过设置空白条目使数据子表的大小为主存块的N倍,其中N为自然数,且 N>2。该技术方案不会出现两个数据子表主存块读入时会交叉覆盖的现象, 不需要重复读入,所以能够降低緩存冲突,提高緩存读取速度。
在本实施例的基础上,在步骤103和104之间,还可以执行下述操作 在存储各数据子表的第一个数据条目的各主存块中设置填充条目,填充条目 设置在主存块中的数据条目之前,且填充条目的空间大小等于緩存块存储空 间的自然数倍。
上述操作具体是在顺序存储数据子表数据条目的第 一个主存块中,设置 一个填充条目,且填充条目的空间大小等于緩存块存储空间的自然数倍,例 如1倍或2倍,其作用是使数据子表的首地址不再映射到一个緩存组的第一 个緩存块中。因为按照组相联方式,每个数据子表的首地址都是映射到缓存 组的第一个緩存块中的,因为主存块数量远远多于緩存块,所以往往有多个 数据子表的首地址映射到同一个緩存组的第一个緩存块中。另外,同一数据 子表中各个数据条目的含义各不相同,其访问频率存在差异,这是由代码逻 辑决定的,当各数据子表在緩存中映射的起始位置相同时,各凝:据子表中访 问频率基本相同的数据条目也会相应的映射到同 一缓存块中,例如目的地址 存储在数据子表的第一个主存块中,那么在映射时,不同数据子表中的目的 地址数据都会映射到同一緩存块中。此时会增加冲突发生的概率,因为访问 频率较高的数据会映射到同一緩存块上,被反覆换入、换出,而访问频率低
的数据同样映射到另一緩存块上,很少被用到,所以高速緩存器没有被充分 利用。这种情况使緩存冲突增加,读写速度下降。上述技术方案恰能够解决
这个緩存冲突的问题, 一个数据子表的首地址是空白的填充条目,而填充条 目的大小等于緩存块的大小,所以数据子表中真正的第一个数据条目会后错,被映射到緩存组的第2、 3……M个緩存块中,后错的位置取决于填充条目的 大小。较佳的技术方案是令各数据子表第一个主存块中填充条目的大小不一 致,数据子表首地址均匀的错开映射至緩存组的各个緩存块中,例如编号分别为0、 1、 2、 3........ X的X个数据子表,4路组相联方式, 一个緩存组包括4个32字节的緩存块,那么"0"号数据子表的第一个主存块中设置32 字节的填充条目,'T,号数据子表的第一个主存块中设置64字节的填充条 目,"2"号数据子表的第一个主存块中设置96字节的填充条目,"3"号 数据子表的第一个主存块中设置128字节的填充条目,填充条目的大小依次 递增,从"5"号数据子表开始循环,其第一个主存块中又设置32字节的填 充条目,该技术方案可以使数据子表的首地址均匀的错开映射。图4所示为 数据表与高速緩存器间映射关系的示意图。该示例采用2路组相联方式,高 速緩存器分为两组,每组包括两个緩存块,主存储器被划分为9个主存块, 从0 8依次编号,数据表包括两个数据子表,每个数据子表又包括两个数据 条目,顺序存储在连续的主存块中,其中,第一个数据子表的第一个主存块, 即第"0"号主存块,按照緩存组号=主存块号mod緩存组数的预设规则(0mod2 =0),映射到第"0"号緩存块中,而第二个数据子表的第一个主存块,即 第"4"号主存块,按照4mod2-()的规则映射到第"0"个緩存组中,因为"2" 号主存块的数据条目前设置了填充条目,所以数据子表的数据条目实际上映 射到第'T,号緩存块中,数据子表其他的主存块相应地顺序映射。当然,具 体的设置方式可以根据主存块、緩存块、緩存组数的情况具体设定。
采用上述技术手段,可以减少緩存冲突。采用本发明上述技术方案使表 项写入高速緩存器时的起始位不同, 一方面不会完全覆盖掉原緩存表项,此 时原緩存表项中没有被覆盖的内容仍然有效,另一方面,访问频率相同的数 据不会映射到相同的緩存块中,能够减少緩存冲突,提高高速緩存器的利用 率,进而提高数据读取速度,改善系统性能。
在上述技术方案的基础上,对主储存器中数据表的数据处理方法的具体实施方式
还可以在将数据子表存储至主存储器的主存块之后执行下述操作 按照所述数据条目的访问频率调整数据条目在所述数据子表中的存储顺序。较佳的实施方式是按照访问频率从高到低的方式进行存储。即按照各数据 条目中所存储的数据的访问频率由高到低的顺序,来形成数据子表,而后存 储在主存块中,第一个主存块中存储的数据访问频率较高,而后随着主存块 号数的增加,所存储数据的访问频率递减,数据的访问频率一般与程序逻辑 相关,而程序逻辑在程序设计完后会基本固定,所以数据的访问频率在设计 完成后一般不再改变,可以据此调整数据的存储顺序,数据子表根据具体情 况也可以不划分为多个条目,而直接将其中的数据按照访问频率。
每个数据子表中数据条目按照访问频率由高到低的顺序排列,会使访问 频率最高的数据条目不同时位于同一緩存块中,使緩存块所映射的数据的访 问频率进一步均匀化。或者至少设置相同或相近访问频率的数据条目存储在 同一主存块中,即各主存块内存储的数据条目访问频率接近,但每个主存块 的访问频率并不是顺序排列的。该技术方案也能使访问频率均勻化,则緩存 冲突可以进一步减少。
采用上述实施例的数据处理方法进行防火墙连接状态数据表的处理操 作,存储于主存储器中,在后续利用高速緩存器从主存储器中读取数据时, 相比于读取传统按照直接、自然的方式去组织的连接状态数据表,可以避免 出现非频繁访问的信息与频繁访问的信息平等占用高速緩存器的现象,从而 能够减少数据读取过程中的緩存沖突,提高读取速度,改善系统的性能,具体可以使防火墙的吞吐率提高5%-10%,降低延迟,改善防火墙系统的性能。
数据处理装置实施例
如图5所示为本发明数据处理装置具体实施例的结构示意图,该装置包 括第一模块100,用于设置用于存储数据子表的主存储器以组相联方式与 高速緩存器相互关联,主存储器包括数个存储空间相等、顺序排列的主存块, 高速緩存器包括数个存储空间相等、顺序排列的緩存块,且主存块存储空间
为緩存块存储空间的两倍或两倍以上;第二模块200,用于将两个或两个以 上、由数个数据条目组成的数据子表顺序存储在主存储器的主存块中;第三 模块300,用于在存储数据子表最后一个数据条目的主存块中,设置用于维 持主存块存储一个数据子表中数据的空白条目,以便调整数据子表的大小等 于主存块存储空间大小的N倍,其中N为自然数,且N》2。
在上述技术方案的基础上,本实施例的数据处理装置中可以进一步包括 第四模块400,用于在存储各数据子表的第一个数据条目的各主存块中设置 填充条目,该填充条目设置在主存块中的数据条目之前,且填充条目的空间 大小等于緩存块存储空间的自然数倍。
进一步的,还可以设置第五模块500,用于按照数据条目的访问频率
调整数据条目在数据子表中的存储顺序。具体可以为调整数据条目在整个数
据子表中按照访问频率由高至低的顺序排列,或者将访问频率相近的数据条
目组织在同一主存块中。
本实施例的数据处理装置还可以包括第六模块600,用于根据高速緩
存器发送的数据读取指示,按照设定规则将指定主存块中的数据读取至緩存
块中。其中的数据读取指示是由高速緩存器发送的,当外部设备从高速緩存
器读取数据时,若高速緩存器中不存在所需数据,则该高速緩存器会向与其
相关联的主存储器发送数据读取指示,将所需数据所在主存块中的所有数据
按照设定规则,读取至高速緩存器的緩存块中,以备外部设备从緩存块中读
取所需数据。
本实施例数据处理装置所执行的方法可以为本发明数据处理方法的任意 实施例。本实施例的数据处理装置可针对数据表采用高速緩存技术进行读取, 可以减少緩存沖突,提高读取速度,改善系统性能。
当然,本发明的数据处理方法和装置并不限于防火墙技术中的数据处理, 在很多网络设备中都存在象防火墙连接状态数据表这样的数据表,例如网络 地址转换(Network Address Translation,简称NAT)设备的地址转换表、 基于流交换设备(路由器、交换机)的流表等等,本发明可适用于其他基于
高速緩存技术进行的数据处理操作过程。
本领域普通技术人员可以理解实现上述方法实施例的全部或部分步骤 可以通过程序指令相关的硬件来完成,前述的程序可以存储于一计算机可读 取存储介质中,该程序在执行时,执行包括上述方法实施例的步骤;而前述 的存储介质包括R0M、 RAM、磁碟或者光盘等各种可以存储程序代码的介质。
最后应说明的是以上实施例仅用以说明本发明的技术方案,而非对其 限制;尽管参照前述实施例对本发明进行了详细的说明,本领域的普通技术 人员应当理解其依然可以对前述各实施例所记载的技术方案进行修改,或 者对其中部分技术特征进行等同替换;而这些修改或者替换,并不使相应技术方案的本质脱离本发明各实施例技术方案的精神和范围。
权利要求
1、一种数据处理方法,其特征在于包括设置用于存储数据子表的主存储器以组相联方式与高速缓存器相互关联,所述主存储器包括数个存储空间相等、顺序排列的主存块,所述高速缓存器包括数个存储空间相等、顺序排列的缓存块,且所述主存块存储空间为所述缓存块存储空间的两倍或两倍以上;将两个或两个以上、由数个数据条目组成的数据子表顺序存储在所述主存储器的主存块中;调整所述数据子表的大小等于所述主存块存储空间大小的N倍,其中N为自然数,且N≥2。
2、 根据权利要求1所述的数据处理方法,其特征在于,调整所述数据子 表的大小等于所述主存块存储空间大小的N倍具体为在存储所述数据子表 最后一个数据条目的所述主存块中,设置用于维持所述主存块存储一个数据 子表中数据的空白条目。
3、 根据权利要求2所述的数据处理方法,其特征在于,在存储所述数据 子表最后一个数据条目的所述主存块中设置所述空白条目之后,还包括在 存储各所述数据子表的第一个数据条目的各主存块中设置填充条目,所述填 充条目设置在所述主存块中的数据条目之前,且所述填充条目的空间大小等 于所述緩存块存储空间的自然数倍。
4、 根据权利要求3所述的数据处理方法,其特征在于,在所述主存块中 设置填充条目具体为在存储各所述数据子表的第一个数据条目的各主存块 中分别设置空间大小递增的填充条目。
5、 根据权利要求2或3或4所述的数据处理方法,其特征在于,在将两 个或两个以上、由数个数据条目组成的数据子表顺序存储在所述主存储器的 主存块中之后,还包括按照所述数据条目的访问频率调整数据条目在所述 数据子表中的存储顺序。
6、 根据权利要求1 ~ 4所述的任一数据处理方法,其特征在于,还包括 从所述高速緩存器读取数据,当所述高速緩存器中不存在所需数据时,从与所述高速緩存器相关联的所述主存储器中,将所需数据所在主存块中的 所有数据按照设定规则,读取至所述高速緩存器的緩存块中; 从所述緩存块中读取所需数据。
7、 一种数据处理装置,其特征在于包括第一模块,用于设置用于存储数据子表的主存储器以组相联方式与高速 緩存器相互关联,所述主存储器包括数个存储空间相等、顺序排列的主存块, 所述高速緩存器包括数个存储空间相等、顺序排列的緩存块,且所述主存块 存储空间为所述緩存块存储空间的两倍或两倍以上;第二模块,用于将两个或两个以上、由数个数据条目组成的数据子表顺 序存储在所述主存储器的主存块中;第三模块,用于在存储所述数据子表最后一个数据条目的所述主存块中, 设置用于维持所述主存块存储一个数据子表中数据的空白条目。
8、 根据权利要求7所述的数据处理装置,其特征在于还包括 第四模块,用于在存储各所述数据子表的第一个数据条目的各主存块中设置填充条目,所述填充条目设置在所述主存块中的数据条目之前,且所述 填充条目的空间大小等于所述緩存块存储空间的自然数倍。
9、 根据权利要求8所述的数据处理装置,其特征在于还包括 第五模块,用于按照所述数据条目的访问频率调整数据条目在所述数据子表中的存储顺序。
10、 根据权利要求9所述的数据处理装置,其特征在于还包括 第六模块,用于根据高速緩存器发送的数据读取指示,按照设定规则将指定主存块中的数据读取至緩存块中。
全文摘要
本发明涉及一种数据处理方法和装置。该方法包括设置主存储器以组相联方式与高速缓存器相互关联,主存储器包括数个存储空间相等、顺序排列的主存块,高速缓存器包括数个存储空间相等、顺序排列的缓存块,且主存块存储空间为缓存块存储空间的两倍或两倍以上;将两个或两个以上、由数个数据条目组成的数据子表顺序存储在主存储器的主存块中;调整数据子表的大小等于主存块存储空间大小的N倍,其中N为自然数,且N≥2。该装置包括用于执行本发明数据处理方法各步骤的模块。本发明的技术方案能够减少采用高速缓存技术访问读取数据过程中出现的高速缓存冲突现象,以提高数据读取的速度,节省系统开销,改善系统的性能。
文档编号G06F12/08GK101201800SQ20071030151
公开日2008年6月18日 申请日期2007年12月21日 优先权日2007年12月21日
发明者陈四强 申请人:福建星网锐捷网络有限公司
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1