std::reference_wrapper<T>::reference_wrapper
来自cppreference.com
< cpp | utility | functional | reference wrapper
| 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); 转换
x 为 T&,然后存储到 t 的引用。此重载只有在 typename std::decay<U>::type 与 reference_wrapper 不是同一类型且表达式 FUN(std::declval<U>()) 为良构时才会参与重载决议,其中 FUN 指名虚构的函数集。
void FUN(T&) noexcept; void FUN(T&&) = delete;
2) 复制构造函数。存储到
other.get() 的引用。参数
| x | - | 要包装的对象 |
| other | - | 另一引用包装器 |
异常
示例
| 本节未完成 原因:暂无示例 |
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
| 缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
|---|---|---|---|
| LWG 2993 | C++11 | 被弃置的 reference_wrapper(T&&) 构造函数在某些情况下干涉重载决议
|
替换成构造函数模板 |