std::optional<T>::value_or
From cppreference.com
| 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) |