std::optional<T>::transform
template< class F > constexpr auto transform( F&& f ) &; |
(1) | (начиная с C++23) |
template< class F > constexpr auto transform( F&& f ) const&; |
(2) | (начиная с C++23) |
template< class F > constexpr auto transform( F&& f ) &&; |
(3) | (начиная с C++23) |
template< class F > constexpr auto transform( F&& f ) const&&; |
(4) | (начиная с C++23) |
Если *this содержит значение, вызывает f с содержащимся значением в качестве аргумента и возвращает std::optional, содержащий результат этого вызова; иначе возвращает пустой std::optional.
Тип содержащегося в результате значения (обозначаемого как U ниже) должен быть объектным типом, отличным от массива, и не должен быть std::in_place_t или std::nullopt_t). Иначе программа некорректна.
U будет std::remove_cv_t<std::invoke_result_t<F, T&>>. Если *this содержит значение, возвращает std::optional<U>, содержащееся значение которого инициализируется напрямую из std::invoke(std::forward<F>(f), **this) (в отличие от and_then(), который должен напрямую возвращать std::optional). Иначе возвращается пустой std::optional<U>.Программа некорректна, если определение переменной
U x(std::invoke(std::forward<F>(f), **this)); некорректно.
U равно std::remove_cv_t<std::invoke_result_t<F, const T&>>.U будет std::remove_cv_t<std::invoke_result_t<F, T>>. Если *this содержит значение, возвращает std::optional<U>, содержащееся значение которого инициализируется напрямую из std::invoke(std::forward<F>(f), std::move(**this)). Иначе возвращается пустой std::optional<U>.Программа некорректна, если определение переменной
U x(std::invoke(std::forward<F>(f), std::move(**this))); некорректно.
U равно std::remove_cv_t<std::invoke_result_t<F, const T>>.Параметры
| f | — | подходящая функция или объект Callable, сигнатура вызова которого возвращает нессылочный тип |
Возвращаемое значение
std::optional, содержащий результат f или пустой std::optional, как описано выше.
Примечание
Поскольку transform напрямую создаёт объект U в нужном месте, а не передаёт его конструктору, std::is_move_constructible_v<U> может быть false.
Поскольку вызываемый объект f не может возвращать ссылочный тип, он не может быть указателем на элемент данных.
В некоторых языках эта операция называется карта.
| Макрос Тестирования функциональности | Значение | Стандарт | Функциональность |
|---|---|---|---|
__cpp_lib_optional |
202110L |
(C++23) | Монадические операции в std::optional |
Пример
#include <iostream>
#include <optional>
struct A { /* ... */ };
struct B { /* ... */ };
struct C { /* ... */ };
struct D { /* ... */ };
auto A_to_B(A) -> B { /* ... */ std::cout << "A => B \n"; return {}; }
auto B_to_C(B) -> C { /* ... */ std::cout << "B => C \n"; return {}; }
auto C_to_D(C) -> D { /* ... */ std::cout << "C => D \n"; return {}; }
void try_transform_A_to_D(std::optional<A> o_A)
{
std::cout << (o_A ? "o_A имеет значение\n" : "o_A пусто\n");
std::optional<D> o_D = o_A.transform(A_to_B)
.transform(B_to_C)
.transform(C_to_D);
std::cout << (o_D ? "o_D имеет значение\n\n" : "o_D пусто\n\n");
};
int main()
{
try_transform_A_to_D( A{} );
try_transform_A_to_D( {} );
}
Вывод:
o_A имеет значение
A => B
B => C
C => D
o_D имеет значение
o_A пусто
o_D пусто
Смотрите также
| возвращает содержащееся значение, если доступно, иначе другое значение (public функция-элемент) | |
(C++23) |
возвращает результат данной функции по содержащемуся значению, если оно существует, или пустой optional в противном случае (public функция-элемент) |
(C++23) |
возвращает сам optional, если он содержит значение, или результат данной функции иначе (public функция-элемент) |