bool contains(const key_type& x) const; // (1) C++23
template <class K>
bool contains(const K& x) const; // (2) C++23
概要
指定されたキーx
に一致する要素がコンテナに含まれているかを判定する。
- (1) : クラスのテンプレートパラメータ
key_type
型のキーを受け取る - (2) :
key_type
と比較可能なK
型のキーを受け取る
テンプレートパラメータ制約
- (2) :
key_compare::is_transparent
が妥当な式であること
戻り値
以下と等価:
計算量
対数時間
備考
- (3) :
is_transparent
は、標準ライブラリのstd::less
、std::greater
といった関数オブジェクトの、void
に対する特殊化で定義される。それ以外のテンプレートパラメータでis_transparent
が定義されないのは、互換性のためである。- これらのオーバーロードは、
flat_map<string, int>
のようなコンテナに対し、検索操作で文字列リテラルを渡した際に、キー型の一時オブジェクトが生成されるコストを減らすためにある。
例
#include <iostream>
#include <flat_map>
int main()
{
std::flat_map<char, int> fm = {
{'a', 3},
{'b', 1},
{'c', 4}
};
// キー'b'の要素が含まれているか
if (fm.contains('b')) {
std::cout << "contain" << std::endl;
}
else {
std::cout << "doesn't contain" << std::endl;
}
}
出力
contain
バージョン
言語
- C++23
処理系
- Clang: ??
- GCC: ??
- Visual C++: ??