boost :: unordered_map缺少像std :: unordered_map这样的reserve()

时间:2012-05-16 11:46:38

标签: c++ unordered-map boost-unordered

对于我的下一个任务,我需要使用一个非常大的哈希值;因为我有一个旧的编译器,所以我不能使用C ++ 0x std::unordered_map。理想情况下,我需要拨打reserve来提前为大量物品腾出空间。我在boost::unordered_map中找不到这种方法:是否有任何地方或功能达到同样的效果?

2个关联容器是相同的;我可以看到rehash函数和用于控制存储桶数量的相同构造函数,但不是关于许多元素的函数。

你能帮帮我吗?

1 个答案:

答案 0 :(得分:6)

reserve可以由rehash模拟,如N3376中的表103所示。

a.rehash(n) 
Post: a.bucket_count() > a.size() / a.max_load_factor() 
      and a.bucket_count() >= n.

a.reserve(n) Same as a.rehash(ceil(n / a.max_load_factor()))