Tars源码分析---内存哈希表的实现

本文深入分析Tars中cpp/util的内存哈希表实现,包括基于内存的TC_HashMap和TC_Multi_HashMap。TC_HashMap采用开链哈希,依赖TC_MemMultiChunkAllocator进行内存管理,支持dump和load操作。TC_Multi_HashMap则增加了多key支持,通过主key和辅key构建联合主键。文章探讨了哈希表的内存结构、功能实现及优化策略。
摘要由CSDN通过智能技术生成

前言

在cpp/util中实现了基于内存的哈希表(hashmap.(cpp,h))。该哈希表支持dump到文件,以及从文件load到内存。在实现上,它基于传统的开链哈希,分别为每个哈希桶维护一个block链表,相同哈希值的kv对散列存储到相同的block链表中。链表中每个block存储具体的一个kv数据。由于hashmap使用TC_MemMultiChunkAllocator进行内存管理,因此它以块为单位使用内存(当然,支持不同大小的块)。hashmap通过在block中维护chunk链表来支持数据操作(主要是set)的灵活性。为了更好和磁盘读写对接(dump,load),hashmap使用的所有内存都属于一块连续的内存空间。除此之外,为了对外提供灵活的会写,备份功能,hashmap还对block建立了多维的管理链表(_iSet,_iGet,….)。

内存结构


这里写图片描述

如上图为hashmap实现的逻辑视图。一个简单的开链哈希算法,并通过tagMapHead对哈希中的block提供多种类型的管理功能。kv值编码成一个二进制序列存储在block-chunk链表中(chunk非必须),kv的编解码使用TC_PackOut/TC_PackIn来完成(tc_Pack.cpp)。当然,hashmap支持只有key的存储,类似STL中的set集合。

为了方便地支持将哈希表dump到文件或者从文件load进入内存,hashmap的实现内存是在一整块连续的内存空间中。如下图所示: <

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值