std::reference_wrapper<T>::reference_wrapper

来自cppreference.com
 
 
 
函数对象
函数包装
(C++11)
(C++11)
部分函数应用
(C++11)
(C++20)
函数调用
(C++17)
恒等函数对象
(C++20)
引用包装
(C++11)(C++11)
运算符包装
取反器
(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 前)
 
 
template< class U >
reference_wrapper( U&& x ) noexcept(/*see below*/) ;
(1)
reference_wrapper( const reference_wrapper& other ) noexcept;
(2)

构造新的 reference_wrapper 。

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 - 另一 reference_wrapper

[编辑] 异常

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

[编辑] 缺陷报告

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

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