std::reference_wrapper<T>::reference_wrapper

来自cppreference.com
 
 
 
函数对象
函数调用
(C++17)(C++23)
恒等函数对象
(C++20)
旧式绑定器与适配器
(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 前*)
 
 
template< class U >
reference_wrapper( U&& x ) noexcept(/* 见下文 */) ;
(1)(C++11 起)
(C++20 起为 constexpr)
reference_wrapper( const reference_wrapper& other ) noexcept;
(2)(C++11 起)
(C++20 起为 constexpr)

构造新的引用包装器。

1) 如同用 T& t = std::forward<U>(x); 转换 xT&,然后存储到 t 的引用。此重载只有在 typename std::decay<U>::typereference_wrapper 不是同一类型且表达式 FUN(std::declval<U>()) 为良构时才会参与重载决议,其中 FUN 指名虚构的函数集。
void FUN(T&) noexcept;
void FUN(T&&) = delete;
2) 复制构造函数。存储到 other.get() 的引用。

参数

x-要包装的对象
other-另一引用包装器

异常

1)
noexcept 说明:  
noexcept(noexcept(FUN(std::declval<U>())))
,其中 FUN 是以上描述中的虚构函数集。

示例

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告应用于出版时的行为正确行为
LWG 2993C++11被弃置的 reference_wrapper(T&&) 构造函数在某些情况下干涉重载决议替换成构造函数模板