public member type
<unordered_map>

std::unordered_multimap::bucket_size

size_type bucket_size ( size_type n ) const;
Return bucket_size
返回桶 n 中的元素數量。

桶(bucket)是容器內部雜湊表中的一個槽,元素根據其鍵的雜湊值被分配到該槽中。

桶中的元素數量會影響訪問桶中特定元素所需的時間。容器會自動增加桶的數量,以確保 負載因子(即平均桶大小)低於其 max_load_factor

引數

n
桶編號。
這應該小於 bucket_count
成員型別size_type是一種無符號整型型別。

返回值

n 中的元素數量。

成員型別size_type是一種無符號整型型別。

示例

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
// unordered_multimap::bucket_size
#include <iostream>
#include <string>
#include <unordered_map>

int main ()
{
  std::unordered_multimap<std::string,std::string> myumm = {
    {"John","Alpha"},
    {"Alfred","Beta"},
    {"Thomas","Gamma"},
    {"John","Delta"}
  };

  unsigned nbuckets = myumm.bucket_count();

  std::cout << "myumm has " << nbuckets << " buckets:\n";

  for (unsigned i=0; i<nbuckets; ++i) {
    std::cout << "bucket #" << i << " has " << myumm.bucket_size(i) << " elements.\n";
  }

  return 0;
}

可能的輸出
myumm has 5 buckets:
bucket #0 has 0 elements.
bucket #1 has 3 elements.
bucket #2 has 0 elements.
bucket #3 has 0 elements.
bucket #4 has 1 elements.


複雜度

線性於桶的大小。

迭代器有效性

沒有變化。

另見