std::experimental::optional<T>:: value_or
From cppreference.net
<
cpp
|
experimental
|
optional
|
template
<
class
U
>
constexpr T value_or ( U && default_value ) const & ; |
(ライブラリファンダメンタルTS) | |
|
template
<
class
U
>
constexpr T value_or ( U && default_value ) && ; |
(ライブラリファンダメンタルTS) | |
* this が値を保持している場合は格納された値を返し、それ以外の場合は default_value を返します。
1)
次と等価:
bool
(
*
this
)
?
**
this
:
static_cast
<
T
>
(
std::
forward
<
U
>
(
default_value
)
)
。
2)
次と同等:
bool
(
*
this
)
?
std
::
move
(
**
this
)
:
static_cast
<
T
>
(
std::
forward
<
U
>
(
default_value
)
)
.
目次 |
パラメータ
| default_value | - | * this が空の場合に使用する値 |
| 型要件 | ||
-
T
はオーバーロード(1)を使用するために
CopyConstructible
の要件を満たさなければならない
|
||
-
T
はオーバーロード(2)を使用するために
MoveConstructible
の要件を満たさなければならない
|
||
-
U&&
は
T
に変換可能でなければならない
|
||
戻り値
現在の値は、 * this が値を持つ場合はその値、それ以外の場合は default_value です。
例外
戻り値
T
の選択されたコンストラクタによってスローされるあらゆる例外。
例
このコードを実行
#include <cstdlib> #include <experimental/optional> #include <iostream> std::experimental::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("MYPWD").value_or("(none)") << '\n'; }
出力例:
(none)
関連項目
|
含まれている値を返す
(public member function) |