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

std::reference_wrapper

Материал из cppreference.com
< cpp‎ | utility‎ | functional
 
 
 
Функция объектов
Функция обертки
Оригинал:
Function wrappers
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
function(C++11)
mem_fn(C++11)
bad_function_call(C++11)
Привязка
Оригинал:
Bind
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
bind(C++11)
is_bind_expression(C++11)
is_placeholder(C++11)
_1, _2, _3, ...(C++11)
Ссылка обертки
Оригинал:
Reference wrappers
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
reference_wrapper(C++11)
ref
cref
(C++11)
(C++11)
Оператор обертки
Оригинал:
Operator wrappers
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Negators
Оригинал:
Negators
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Устаревшие связующих и адаптеры
Оригинал:
Deprecated binders and adaptors
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
unary_function(устарело)
binary_function(устарело)
ptr_fun(устарело)
pointer_to_unary_function(устарело)
pointer_to_binary_function(устарело)
mem_fun(устарело)
mem_fun_t
mem_fun1_t
const_mem_fun_t
const_mem_fun1_t
(устарело)
(устарело)
(устарело)
(устарело)
mem_fun_ref(устарело)
mem_fun_ref_t
mem_fun1_ref_t
const_mem_fun_ref_t
const_mem_fun1_ref_t
(устарело)
(устарело)
(устарело)
(устарело)
binder1st
binder2nd
(устарело)
(устарело)
bind1st
bind2nd
(устарело)
(устарело)
 
 
Определено в заголовочном файле <functional>
template< class T >
class reference_wrapper;
(начиная с C++11)

Шаблонный класс std::reference_wrapper это CopyConstructible и CopyAssignable обертка над ссылкой на объект или на функцию типа T. Экземпляры std::reference_wrapper являются объектами (могут быть скопированы или храниться в контейнерах), но они неявно преобразуются в T&, так что они могут быть использованы в качестве аргументов функций, которые принимают базовый тип по ссылке.

Вспомогательные функции std::ref и std::cref часто используются для создания объектов std::reference_wrapper.

std::reference_wrapper также используется для передачи объектов по ссылке в std::bind или конструктор std::thread по ссылке.

Содержание

[править] Типы-члены

Тип Описание
type T
result_type Тип возвращаемого T если T является функцией. В противном случае, не определено.
argument_type 1) если T является функцией или указателем на функцию, которая принимает один аргумент типа A1, то argument_type является A1.

2) если T является указателем на функцию-член класса T0, который не принимает аргументов, то argument_type является T0*, возможно, CV-qualified
3) если T это класс с членом типа T::argument_type, то argument_type является его псевдонимом

first_argument_type 1) если T является функцией или указателем на функцию, которая принимает два аргумента с типами A1 и A2, то first_argument_type является A1.

2) если T является указателем на функцию-член класса T0, которая принимает один аргумент, то first_argument_type является T0*, возможно, CV-qualified
3) если T это тип класса типом члена класса T::first_argument_type, то first_argument_type является его псевдонимом

second_argument_type

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

содержит ссылку на новый объект std::reference_wrapper
Оригинал:
stores a reference in a new std::reference_wrapper object
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

(public функция-член) [править]
повторную привязку std::reference_wrapper
Оригинал:
rebinds a std::reference_wrapper
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

(public функция-член) [править]
доступ к сохраненной ссылке
Оригинал:
accesses the stored reference
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

(public функция-член) [править]
вызывает хранимую функцию
Оригинал:
calls the stored function
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

(public функция-член) [править]

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

Демонстрируется использование reference_wrapper в качестве контейнера ссылок, которые позволяют получить доступ к тому же контейнеру с помощью нескольких индексов

#include <algorithm>
#include <list>
#include <vector>
#include <iostream>
#include <functional>
 
int main()
{
    std::list<int> l = {-4, -3, -2, -1, 0, 1, 2, 3, 4};
 
    std::vector<std::reference_wrapper<int>> v(l.begin(), l.end());
    std::random_shuffle(v.begin(), v.end());
 
    std::vector<std::reference_wrapper<int>> v2(v.begin(), v.end());
    std::partition(v2.begin(), v2.end(), [](int n){return n<0;});
 
    std::cout << "Contents of the list: ";
    for(int n: l) {
        std::cout << n << ' ';
    }
    std::cout << '\n';
 
    std::cout << "Contents of the list, shuffled: ";
    for(int i: v) {
        std::cout << i << ' ';
    }
    std::cout << '\n';
 
    std::cout << "Shuffled elements, partitioned: ";
    for(int i: v2) {
        std::cout << i << ' ';
    }
    std::cout << '\n';
}

Вывод:

Contents of the list: -4 -3 -2 -1 0 1 2 3 4
Contents of the list, shuffled: 0 -1 3 4 -4 1 -2 -3 2
Shuffled elements, partitioned: -3 -1 -2 -4 4 1 3 0 2

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

(C++11)
(C++11)
создает std::reference_wrapper с типом выводится из своих аргументов
Оригинал:
creates a std::reference_wrapper with a type deduced from its argument
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

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