名前空間
変種
操作

std::optional<T>::value

From cppreference.com
< cpp‎ | utility‎ | optional
 
 
ユーティリティライブラリ
言語サポート
型のサポート (基本型、RTTI)
ライブラリ機能検査マクロ (C++20)
プログラムユーティリティ
可変引数関数
コルーチンサポート (C++20)
契約サポート (C++26)
三方比較
(C++20)
(C++20)(C++20)(C++20)  
(C++20)(C++20)(C++20)

汎用ユーティリティ
関係演算子 (C++20で非推奨)
 
 
constexpr T& value() &;
constexpr const T& value() const &;
(1) (C++17以降)
constexpr T&& value() &&;
constexpr const T&& value() const &&;
(2) (C++17以降)

*this が値を保持している場合、保持している値への参照を返します。

それ以外の場合、std::bad_optional_access 例外をスローします。

目次

[編集] パラメータ

(なし)

[編集] 戻り値

保持している値への参照。

[編集] 例外

std::bad_optional_access: *this が値を保持していない場合。

[編集] 注記

デリファレンス演算子 operator*() は、この optional が値を保持しているかチェックしません。これは value() よりも効率が良い場合があります。

[編集]

#include <iostream>
#include <optional>
 
int main()
{
    std::optional<int> opt = {};
 
    try
    {
        [[maybe_unused]] int n = opt.value();
    }
    catch(const std::bad_optional_access& e)
    {
        std::cout << e.what() << '\n';
    }
 
    try
    {
        opt.value() = 42;
    }
    catch(const std::bad_optional_access& e)
    {
        std::cout << e.what() << '\n';
    }
 
    opt = 43;
    std::cout << *opt << '\n';
 
    opt.value() = 44;
    std::cout << opt.value() << '\n';
}

出力

bad optional access
bad optional access
43
44

[編集] 関連項目

保持されている値が利用可能であればそれを返し、そうでなければ別の値を返す
(public member function) [編集]
保持されている値にアクセスする
(public member function) [編集]
値を保持していない optional へのチェック付きアクセスを示す例外
(class) [編集]
English 日本語 中文(简体) 中文(繁體)