- flat_map[meta header]
- std[meta namespace]
- flat_multimap[meta class]
- function[meta id-type]
- cpp23[meta cpp]
size_type count(const key_type& x) const; // (1) C++23
template <class K>
size_type count(const K& x) const; // (2) C++23
キー x
を検索し、コンテナ内に見つかった要素の数を返す。
- (1) : クラスのテンプレートパラメータ
key_type
型のキーx
を受け取って、x
と等価なキーを持つ要素の数を取得する。 - (2) :
key_type
と比較可能なK
型のキーx
を受け取って、x
と等価なキーを持つ要素の数を取得する。
- (2) :
key_compare::is_transparent
が妥当な式であること
- (1) :
x
と等価なキーの要素数を返す。 - (2) :
key_compare
型の関数オブジェクトをc
、コンテナ内の各要素が持つキーをk
として、キーが等価か判定する式!c(k, x) && !c(x, k)
がtrue
となる要素の数を返す。
log(size()) + count(x)
- size()[link size.md]
- (2) :
is_transparent
は、標準ライブラリのstd::less
、std::greater
といった関数オブジェクトの、void
に対する特殊化で定義される。それ以外のテンプレートパラメータでis_transparent
が定義されないのは、互換性のためである。- これらのオーバーロードは、
flat_multimap<string, int>
のようなコンテナに対し、検索操作で文字列リテラルを渡した際に、キー型の一時オブジェクトが生成されるコストを減らすためにある。
#include <flat_map>
#include <iostream>
#include <string>
int main()
{
// (1)
{
std::flat_multimap<std::string, int> fm = {
{"Alice", 3},
{"Bob", 1},
{"Carol", 4}
};
std::cout << fm.count("Bob") << std::endl;
}
// (2)
{
std::flat_multimap<std::string, int, std::less<>> fm = {
{"Alice", 3},
{"Bob", 1},
{"Carol", 4}
};
// std::lessのvoidに対する特殊化を使用することで、
// 文字列リテラルをcount()関数の引数として渡した際に、
// std::string型の一時オブジェクトが生成されない。
std::cout << fm.count("Bob") << std::endl;
}
}
- fm.count[color ff0000]
- std::less[link /reference/functional/less.md]
1
1
- C++23
- Clang: ??
- GCC: ??
- Visual C++: ??