[发明专利]一种哈希表的处理方法有效
| 申请号: | 202110776008.7 | 申请日: | 2021-07-09 |
| 公开(公告)号: | CN113505130B | 公开(公告)日: | 2023-07-21 |
| 发明(设计)人: | 熊子威;蒋德钧;熊劲 | 申请(专利权)人: | 中国科学院计算技术研究所 |
| 主分类号: | G06F16/22 | 分类号: | G06F16/22 |
| 代理公司: | 北京泛华伟业知识产权代理有限公司 11280 | 代理人: | 王勇 |
| 地址: | 100190 北*** | 国省代码: | 北京;11 |
| 权利要求书: | 查看更多 | 说明书: | 查看更多 |
| 摘要: | |||
| 搜索关键词: | 一种 哈希表 处理 方法 | ||
1.一种哈希表的处理方法,所述哈希表为聚合的可拓展哈希表,包括多个可拓展哈希表,每个可拓展哈希表构成所述聚合的可拓展哈希表的一层,所述可拓展哈希表包括不少于一个的桶,所述桶用于存储键值对数据;所述可拓展哈希表具有相同编号的桶构成所述聚合的可拓展哈希表的一个段;所述聚合的可拓展哈希表包括共享目录,所述共享目录用于管理聚合的可扩展哈希表的全局深度以及段的指针;所述处理方法包括:
计算输入键值对中键的哈希值H;
取H的最低G位为下标,在共享目录中索引相应的指针,获得相应的指针所指向的段;
取H的最高位为下标,在段内索引一个桶;
在桶内进行线性查找、插入或删除;
G为哈希表的全局深度,K为哈希表的层数,
其中,当插入操作需要一个桶分裂并且共享目录容量不足时,利用全分裂方法扩张哈希表容量,所述全分裂方法包括:
生成一个分裂桶所在段的伙伴段,伙伴段中与分裂桶同层的桶构成分裂桶的伙伴桶;
将共享目录的容量倍增;
将所述伙伴段的指针加入共享目录;
将新的键值对插入伙伴桶中,根据键的哈希值迁移分裂桶中的部分键值对到伙伴桶中;
将伙伴段的其它后代桶的祖先指针指向其最年轻的祖先桶;
将全局深度加1,分裂桶的局部深度加1,将伙伴桶深度设置为与分裂桶相同;
当插入操作需要一个桶分裂且共享目录容量充足时,利用基础分裂方法扩张容量,所述基础分裂方法包括:
生成一个分裂桶所在段的伙伴段,伙伴段中与分裂桶同层的桶构成分裂桶的伙伴桶;
将所述伙伴段的指针加入共享目录;
将新的键值对插入伙伴桶中,根据键的哈希值迁移分裂桶中的部分键值对到伙伴桶中;
将伙伴段的其它后代桶的祖先指针指向其最年轻的祖先桶;
将分裂桶的局部深度加1,将伙伴桶深度设置为与分裂桶相同;
当插入操作需要一个桶分裂并且其所在段的伙伴段已经存在时,利用快速分裂方法扩张容量,所述快速分裂方法包括:
将分裂桶对应的后代桶设置为伙伴桶,将伙伴桶的祖先指针设置为无效;
将新的键值对插入伙伴桶中,将分裂桶的部分键值对移至伙伴桶中;
将分裂桶的局部深度加1,将伙伴桶深度设置为与分裂桶相同。
2.根据权利要求1所述的处理方法,其中基于锁访问所述哈希表。
3.根据权利要求2所述的处理方法,所述哈希表存储于NVM,所述锁放置于DRAM。
4.根据权利要求3所述的处理方法,所述锁包括全局锁,所述全局锁用于所述共享目录的扩张;所述锁包括段锁,所述段锁用于分配新的段。
5.根据权利要求4所述的处理方法,所述锁包括用于访问每个所述桶的读者锁,所述读者锁用于在访问桶时保护当前读操作以及避免阻塞其它读操作;所述锁包括每个桶的写者锁,所述写者锁用于在插入操作和/或删除操作时的并发控制。
6.一种计算机可读存储介质,其上存储有计算机程序,其中,该程序被处理器执行时实现根据权利要求1至5任一项所述方法的步骤。
7.一种计算机设备,包括存储器和处理器,在所述存储器上存储有能够在处理器上运行的计算机程序,其特征在于,所述处理器执行所述程序时实现权利要求1至5任一项所述方法的步骤。
该专利技术资料仅供研究查看技术是否侵权等信息,商用须获得专利权人授权。该专利全部权利属于中国科学院计算技术研究所,未经中国科学院计算技术研究所许可,擅自商用是侵权行为。如果您想购买此专利、获得商业授权和技术合作,请联系【客服】
本文链接:http://www.vipzhuanli.com/pat/books/202110776008.7/1.html,转载请声明来源钻瓜专利网。





