最終更新日時(UTC):
が更新

履歴 編集

function
<flat_map>

std::flat_map::at(C++23)

mapped_type& at(const key_type& x);             // (1) C++23

template <class K>
mapped_type& at(const K& x);                    // (2) C++23

const mapped_type& at(const key_type& x) const; // (3) C++23

template <class K>
const mapped_type& at(const K& x) const;        // (4) C++23

概要

指定したキーを持つ要素を取得する。
要素を取り出す際にキーの存在チェックをする。

  • (1), (3) : クラスのテンプレートパラメータkey_type型のキーを受け取る
  • (2), (4) : key_typeと比較可能なK型のキーを受け取る

テンプレートパラメータ制約

  • (2), (4) : key_compare::is_transparentが妥当な式であること

事前条件

  • (2), (4) : find(x)という式が妥当であり、動作が明確に定義されていること

戻り値

キーxに対応する値を返す。対応する要素が存在しないときは、out_of_range例外を投げる。

計算量

要素数に対して対数時間

備考

  • (2), (4) :
    • is_transparentは、標準ライブラリのstd::lessstd::greaterといった関数オブジェクトの、voidに対する特殊化で定義される。それ以外のテンプレートパラメータでis_transparentが定義されないのは、互換性のためである。
    • これらのオーバーロードは、flat_map<string, int>のようなコンテナに対し、検索操作で文字列リテラルを渡した際に、キー型の一時オブジェクトが生成されるコストを減らすためにある。

#include <iostream>
#include <flat_map>
#include <stdexcept>

template<class Container, class T>
void at_wrap(Container& c, T v)
{
  try {
    std::cout << c.at(v) << std::endl;
  }
  catch(std::out_of_range&) {
    std::cout << "exception std::out_of_range" << std::endl;
  }
}

int main()
{
  std::flat_map<int,char> fm;
  fm.insert(std::make_pair(1, 'a'));

  at_wrap(fm, 1);
  at_wrap(fm, 2);
}

出力

a
exception std::out_of_range

バージョン

言語

  • C++23

処理系

関連項目