hash_map 桶扩张逻辑

新增时

if( newTotalsize > curBucketNum)
{
       找到能容纳newTotalsize 的最近的桶个数__n
       if(__n > curBucketNum)
       {
             则重新分配桶。 并复制旧桶中所有元素。
       }
}
即,假设当前桶个数为53. 当前总元素是96个。 要插入一个时变为97, 进入第一个if。97个总元素时, 最近的桶个数__n也是97ul > curBucketNum, 进入第二个if;
将当前桶数从53扩张到97. 

类似, 当总元素达到193时继续扩展到桶数为193.


元素的所在桶的下标计算方式是 hash(key)%curBucketNum。 stl中的hash_map只能加一把锁、 加多把锁会出现错误【在同时插入可能引起扩张时。】。
自实现的hash_map可以考虑多把锁。

  static const unsigned long __stl_prime_list[_S_num_primes] =
    {
      53ul,         97ul,         193ul,       389ul,       769ul,
      1543ul,       3079ul,       6151ul,      12289ul,     24593ul,
      49157ul,      98317ul,      196613ul,    393241ul,    786433ul,
      1572869ul,    3145739ul,    6291469ul,   12582917ul,  25165843ul,
      50331653ul,   100663319ul,  201326611ul, 402653189ul, 805306457ul,
      1610612741ul, 3221225473ul, 4294967291ul
    };

  inline unsigned long
  __stl_next_prime(unsigned long __n)//找到小于且最接近__n的质数。
  {
    const unsigned long* __first = __stl_prime_list;
    const unsigned long* __last = __stl_prime_list + (int)_S_num_primes;
    const unsigned long* pos = std::lower_bound(__first, __last, __n);
    return pos == __last ? *(__last - 1) : *pos;
  }


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值