模板演绎/重载分辨率有利于 T&& 而不是常量 T&
Template deduction/overload resolution favors T&& over const T&
我有一对定义如下的函数模板:
template<typename CollectionType>
Foo<CollectionType> f(const CollectionType& v)
{
return Foo<CollectionType>(v); // copies v into a member variable
}
template<typename CollectionType>
Foo<CollectionType> f(CollectionType&& v)
{
return Foo<CollectionType>(std::move(v)); // moves v into a member variable
}
如果我按以下方式调用f
:
std::vector<int> v;
f(v);
VC++编译器支持&&
重载,显然是因为它不太专业。我希望在这种情况下调用const&
重载——&&
版本适用于类似f(ReturnAVector())
的构造。有没有一种方法可以在不手动指定模板参数的情况下实现这一点?
经过相当多的努力,我想出了这个:
template<typename CollectionType>
Foo<CollectionType> f(const CollectionType& v)
{
return Foo<CollectionType>(v); // copies v into a member variable
}
template<typename CollectionType>
typename std::enable_if<std::is_rvalue_reference<CollectionType&&>::value,
Foo<typename std::remove_reference<CollectionType>::type>>::type
f(CollectionType&& v)
{
return Foo<CollectionType>(std::move(v)); // moves v into a member variable
}
但是哇;这真的是得到我想要的东西的最简单的方法吗?
带有:
std::vector<int> v;
f(v);
你叫f(std::vector<int>&)
所以
template<typename CollectionType>
Foo<CollectionType> f(CollectionType&& v)
是完全匹配(通用参考)CollectionType
是std::vector<int>&
而
template<typename CollectionType>
Foo<CollectionType> f(const CollectionType& v)
需要const升级。
一个可能的解决方案是添加一个非常量版本:
template<typename CollectionType>
Foo<CollectionType> f(CollectionType& v)
或者转发你的论点,比如:
template<typename CollectionType>
Foo<typename std::remove_reference<CollectionType>::type>
f(CollectionType&& v)
{
return Foo<typename std::remove_reference<CollectionType>::type>(std::forward<CollectionType>(v));
}
第二个重载总是完全匹配的。因此,事实上不需要第一次过载,它只会引起歧义。你不应该继续争论,而应该继续争论。
template<typename CollectionType>
Foo<CollectionType> f(CollectionType&& v)
{
return Foo<CollectionType>(std::forward<CollectionType>(v));
}
Scott Meyers对此给出了很好的解释:http://scottmeyers.blogspot.nl/2012/11/universal-references-in-c11-now-online.html
相关文章:
- #定义c-预处理器常量..我做错了什么
- 用C++中的一个变量定义一个常量
- 什么时候在C++中返回常量引用是个好主意
- 代理对象的常量正确性
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 通过多个头文件使用常量变量
- 在cuda线程之间共享大量常量数据
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 是默认情况下分配给char数组常量的值
- 私有类型的静态常量成员
- 类似枚举的计算常量
- 递归模板化函数不能分配给具有常量限定类型"const tt &"的变量"state"
- 为什么我可以通过引用修改常量返回
- 如何创建长度由常量参数指定的数组
- 当一个值是非常量但用常量表达式初始化时使用constexpr
- 返回常量对象引用 (getter) 和仅返回字符串有什么区别?
- 隐式常量/非常量运算符布尔
- 非常量变量只读位置的赋值
- 模板演绎/重载分辨率有利于 T&& 而不是常量 T&