std::reference_wrapper
![]() |
Эта страница была переведена автоматически с английской версии вики используя Переводчик Google.
Перевод может содержать ошибки и странные формулировки. Наведите курсор на текст, чтобы увидеть оригинал. Вы можете помочь в исправлении ошибок и улучшении перевода. Для инструкций перейдите по ссылке. Щёлкните здесь, чтобы увидеть английскую версию этой страницы |
Определено в заголовочном файле <functional>
|
||
template< class T > class reference_wrapper; |
(начиная с C++11) | |
std::reference_wrapper
класса шаблона CopyConstructible
и CopyAssignable
оберткой ссылку на объект или ссылку на функцию типа T
. Экземпляры std::reference_wrapper
являются объектами (могут быть скопированы или храниться в контейнерах), но они неявно преобразуются в T&, так что они могут быть использованы в качестве аргументов функций, которые принимают базового типа по ссылке.std::reference_wrapper
is a CopyConstructible
and CopyAssignable
wrapper around a reference to object or reference to function of type T
. Instances of std::reference_wrapper
are objects (can be copied or stored in containers), but they are implicitly convertible to T&, so that they can be used as arguments with the functions that take the underlying type by reference.Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
std::reference_wrapper
. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
std::reference_wrapper
также используется для передачи объектов в std::bind или конструктор std::thread по ссылке.std::reference_wrapper
is also used to pass objects to std::bind or to the constructor of std::thread by reference.Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
Содержание |
[править] Типы-члены
типа
Оригинал: type Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
definition |
type
|
T
|
result_type
|
Тип возвращаемого
T если T является функцией. В противном случае, не определен Оригинал: The return type of T if T is a function. Otherwise, not defined Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
argument_type
|
1) если
T является функцией или указателем на функцию, которая принимает один аргумент типа A1 , то argument_type является A1 .2) если T это класс с T::argument_type член типа, то argument_type является псевдонимом этогоОригинал: 1) if T is a function or pointer to function that takes one argument of type A1 , then argument_type is A1 .2) if T is a class type with a member type T::argument_type , then argument_type is an alias of thatТекст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
first_argument_type
|
1) если
T является функцией или указателем на функцию, которая принимает два аргумента типа с A1 и A2 , то first_argument_type является A1 .2) если Оригинал: 1) if T is a function or pointer to function that takes two arguments of type s A1 and A2 , then first_argument_type is A1 .2) if Текст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
second_argument_type
|
1) если
T является функцией или указателем на функцию, которая принимает два аргумента типа с A1 и A2 , то second_argument_type является A2 .2) если T это класс с T::second_argument_type член типа, то first_argument_type является псевдонимом этогоОригинал: 1) if T is a function or pointer to function that takes two arguments of type s A1 and A2 , then second_argument_type is A2 .2) if T is a class type with a member type T::second_argument_type , then first_argument_type is an alias of thatТекст был переведён автоматически используя Переводчик Google. Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда. |
[править] Функции-члены
содержит ссылку на новый объект 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 функция-член) |
[править] Пример
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
#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) |
связывает один или несколько аргументов функции-объекта (шаблон функции) |