Пространства имён
Варианты
Действия

std::move_only_function

Материал из cppreference.com
< cpp‎ | utility‎ | functional
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
Общие утилиты
Дата и время
Функциональные объекты
Библиотека форматирования (C++20)
(C++11)
Операторы отношения (устарело в C++20)
Целочисленные функции сравнения
(C++20)(C++20)(C++20)    
(C++20)
Операции обмена и типа
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Общие лексические типы
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
Объекты функции
Функции обёртки
(C++11)
move_only_function
(C++23)
(C++11)
Применение частичных функций
(C++20)(C++23)
(C++11)
Вызов функции
(C++17)(C++23)
Объект идентичности функции
(C++20)
Обёртки ссылок
(C++11)(C++11)
Прозрачные обёртки операторов
(C++14)
(C++14)
(C++14)
(C++14)  
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)
(C++14)

Отрицатели
(C++17)
Искатели
Ограниченные компараторы
Старые привязки и адаптеры
(до C++17*)
(до C++17*)
(до C++17*)
(до C++17*)
(до C++17*)(до C++17*)(до C++17*)(до C++17*)
(до C++20*)
(до C++20*)
(до C++17*)(до C++17*)
(до C++17*)(до C++17*)

(до C++17*)
(до C++17*)(до C++17*)(до C++17*)(до C++17*)
(до C++20*)
(до C++20*)
 
 
Определено в заголовочном файле <functional>
template< class... >
class move_only_function; // не определено
(1) (начиная с C++23)
template< class R, class... Args >

class move_only_function<R(Args...)>;
template< class R, class... Args >
class move_only_function<R(Args...) noexcept>;
template< class R, class... Args >
class move_only_function<R(Args...) &>;
template< class R, class... Args >
class move_only_function<R(Args...) & noexcept>;
template< class R, class... Args >
class move_only_function<R(Args...) &&>;
template< class R, class... Args >
class move_only_function<R(Args...) && noexcept>;
template< class R, class... Args >
class move_only_function<R(Args...) const>;
template< class R, class... Args >
class move_only_function<R(Args...) const noexcept>;
template< class R, class... Args >
class move_only_function<R(Args...) const &>;
template< class R, class... Args >
class move_only_function<R(Args...) const & noexcept>;
template< class R, class... Args >
class move_only_function<R(Args...) const &&>;
template< class R, class... Args >

class move_only_function<R(Args...) const && noexcept>;
(2) (начиная с C++23)

Шаблонный класс std::move_only_function это универсальная полиморфная оболочка функции. Объекты std::move_only_function могут хранить и вызывать любые конструируемые объекты (не обязательно должны быть конструируемыми для перемещения) Callable цели -- функции, лямбда-выражения, выражения привязки или другие объекты-функции, а также указатели на функции-элементы и указатели на объекты-элементы.

Сохранённый вызываемый объект называется целью класса std::move_only_function. Если std::move_only_function не содержит цели, он называется пустым. В отличие от std::function, вызов пустого std::move_only_function приводит к неопределённому поведению.

std::move_only_function поддерживает все возможные комбинации cv-квалификаторов, ссылочных-квалификаторов и noexcept-квалификаторов не включая volatile, указанных в его параметре шаблона. Эти квалификаторы и спецификатор (если есть) добавляются к его operator().

std::move_only_function соответствует требованиям MoveConstructible и MoveAssignable, но не соответствует CopyConstructible или CopyAssignable.

Содержание

[править] Типы элементы

Тип Определение
result_type R

[править] Функции-элементы

создаёт новый объект std::move_only_function
(public функция-элемент) [править]
уничтожает объект std::move_only_function
(public функция-элемент) [править]
(C++23)
заменяет или уничтожает цель
(public функция-элемент) [править]
(C++23)
меняет местами цели двух объектов std::move_only_function
(public функция-элемент) [править]
проверяет, есть ли у std::move_only_function цель
(public функция-элемент) [править]
вызывает цель
(public функция-элемент) [править]

[править] Функции, не являющиеся элементами

перегружает алгоритм std::swap
(функция) [править]
сравнивает std::move_only_function с nullptr
(функция) [править]

[править] ��римечание

Реализации могут хранить вызываемый объект небольшого размера в объекте std::move_only_function. Такая оптимизация небольших объектов фактически необходима для указателей на функции и специализаций std::reference_wrapper и может применяться только к типам T, для которых std::is_nothrow_move_constructible_v<T> равно true.

Если std::move_only_function, возвращающий ссылку, инициализируется из функции или объекта функции, возвращающих значение prvalue (включая лямбда-выражение без завершающего возвращаемого типа), программа некорректна, поскольку привязка возвращаемой ссылки на временный объект запрещена. Смотрите также примечания std::function.

Макрос Тестирования функциональности Значение Стандарт Функциональность
__cpp_lib_move_only_function 202110L (C++23) std::move_only_function

[править] Пример

#include <iostream>
#include <functional>
#include <future>
 
int main()
{
    std::packaged_task<double()> packaged_task([](){ return 3.14159; });
 
    std::future<double> future = packaged_task.get_future();
 
    auto lambda = [task = std::move(packaged_task)]() mutable { task(); };
 
//  std::function<void()> function = std::move(lambda); // Ошибка
    std::move_only_function<void()> function = std::move(lambda); // OK
 
    function();
 
    std::cout << future.get();
}

Вывод:

3.14159

[править] Смотрите также

(C++11)
обёртывает вызываемый объект любого конструируемого копированием типа с указанной сигнатурой вызова функции
(шаблон класса) [править]