std::reference_wrapper::reference_wrapper

来自cppreference.com
 
 
 
函数对象
函数包装
(C++11)
(C++11)
绑定
(C++11)
函数调用
(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 前)
 
 
(1)
reference_wrapper( T& x ) noexcept;
reference_wrapper( T&& x ) = delete;
(C++20 前)
template< class U >
reference_wrapper( U&& x ) noexcept(/*see below*/) ;
(C++20 起)
reference_wrapper( const reference_wrapper& other ) noexcept;
(2)

构造新的 reference_wrapper 。

1) 存储到 x 的引用。不允许从临时对象构造。

(C++20 前)

1)如同用 T& t = std::forward<U>(x); 转换 xT& ,然后存储到 t 的引用。此重载仅若 std::is_same_v<std::remove_cvref_t<U>, reference_wrapper>false 且表达式 FUN(std::declval<U>()) 为良式才参与重载决议,其中 FUN 指名虚构函数集

void FUN(T&) noexcept;
void FUN(T&&) = delete;
(C++20 起)

2) 复制构造函数。存储到 other.get() 的引用。

[编辑] 参数

x - 要包装的对象
other - 另一 reference_wrapper

[编辑] 异常

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

[编辑] 注意

C++20 前,参数为 T&& 的被删除构造函数仍然参与隐式转换序列的构成,这能在重载决议中导致不期待的结果。 C++20 更改(经由 LWG 问题 2993 )修正此问题。