名前空間
変種
操作

std::optional<T>::value_or

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で非推奨)
 
 
template< class U = std::remove_cv_t<T> >
constexpr T value_or( U&& default_value ) const&;
(1) (C++17以降)
template< class U = std::remove_cv_t<T> >
constexpr T value_or( U&& default_value ) &&;
(2) (C++17以降)

もし*thisが値を保持している場合は、その保持している値を返し、そうでなければdefault_valueを返します。

1) もしstd::is_copy_constructible_v<T> && std::is_convertible_v<U&&, T>falseである場合、プログラムは不適格(ill-formed)となります。
2) もしstd::is_move_constructible_v<T> && std::is_convertible_v<U&&, T>falseである場合、プログラムは不適格(ill-formed)となります。

目次

[edit] パラメータ

default_value - *thisが値を保持していない場合に返される値

[edit] 戻り値

1) has_value() ? **this : static_cast<T>(std::forward<U>(default_value));
2) has_value() ? std::move(**this) : static_cast<T>(std::forward<U>(default_value))

[edit]

#include <cstdlib>
#include <iostream>
#include <optional>
 
std::optional<const char*> maybe_getenv(const char* n)
{
    if (const char* x = std::getenv(n))
        return x;
    else
        return {};
}
 
int main()
{
    std::cout << maybe_getenv("SHELL").value_or("(none)") << '\n';
    std::cout << maybe_getenv("MYPWD").value_or("(none)") << '\n';
}

実行結果の例

/usr/bin/zsh
(none)

[edit] 欠陥報告

以下の動作変更を伴う欠陥報告が、以前に公開されたC++標準に遡って適用されました。

DR 適用対象 公開された動作 正しい動作
LWG 3886 C++17 U にはデフォルトテンプレート引数がありません 指定された

[edit] 関連項目

保持されている値を返す
(public member function) [編集]
English 日本語 中文(简体) 中文(繁體)