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

swap(std::move_only_function)

Материал из cppreference.com
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, 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)
(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*)
 
 
friend void swap( move_only_function& lhs, move_only_function& rhs ) noexcept;
(начиная с C++23)

Перегружает алгоритм std::swap для std::move_only_function. Меняет состояние lhs на rhs. Эффективно вызывает lhs.swap(rhs).

Эта функция не видна обычному неквалифицированному или квалифицированному поиску и может быть найдена только с помощью зависящего от аргумента поиска, когда std::move_only_function<FunctionType> является ассоциированным классом аргументом.

Содержание

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

lhs, rhs объекты std::move_only_function, состояния которых нужно поменять местами

[править] Возвращаемое значение

(нет)

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

#include <concepts>
#include <functional>
#include <iostream>
 
void foo(const char* str, int x) {
    std::cout << "foo(\"" << str << "\", " << x << ")\n";
}
 
void bar(const char* str, int x) {
    std::cout << "bar(\"" << str << "\", " << x << ")\n";
}
 
int main()
{
    std::move_only_function<void(const char*, int) const> f1{ foo };
    std::move_only_function<void(const char*, int) const> f2{ bar };
 
    f1("f1", 1);
    f2("f2", 2);
 
    std::cout << "std::ranges::swap(f1, f2);\n";
    std::ranges::swap(f1, f2); // находит скрытую дружественную функцию
 
    f1("f1", 1);
    f2("f2", 2);
}

Вывод:

foo("f1", 1)
bar("f2", 2)
std::ranges::swap(f1, f2);
bar("f1", 1)
foo("f2", 2)

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

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