为什么在c++ 11中将std::pair类标准更改为不允许只有非常量复制构造函数的类型?
Why was the std::pair class standard changed to disallow types with only a nonconstant copy constructor in C++11?
我正在通读Nicolai M. Josuttis的《c++标准库(第二版)》,刚刚读到关于std::pair
的部分。作者注意到:
从c++ 11开始,使用只有非常量复制构造函数的类型的
pair<>
将不再编译。
他接着给出了下面的例子:
class A
{
public:
...
A( A& ); // copy constructor with nonconstant reference
...
};
std::pair<A, int> p; // Error since C++11
然而,我对标准委员会决定对标准库标准进行此修订的原因很感兴趣?我试着用谷歌搜索原因,但没有找到任何相关的信息。
在c++ 98中,带有非常量引用形参的复制构造函数将(ab)用于"移动"元素。这样的代码是出了名的不安全和不清晰。臭名昭著的、现在已被弃用的std::auto_ptr
就是最好的例子。
在c++ 11中,我们有移动语义和右值引用来更安全、更清晰地实现相同的效果。这是因为右值引用是对可变对象的引用,但它只能绑定到"安全"表达式,例如临时表达式或您(通过std::move
)显式强制转换的内容,因此标记为可丢弃的。
简而言之:复制构造函数接受非引用成员的类没有不能用右值引用更好、更安全的实际用例。std::pair
获得了一个move构造函数std::pair(std::pair&&)=default
来适应这种语义。
相关文章:
- #定义c-预处理器常量..我做错了什么
- 用C++中的一个变量定义一个常量
- 什么时候在C++中返回常量引用是个好主意
- 代理对象的常量正确性
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 通过多个头文件使用常量变量
- 在cuda线程之间共享大量常量数据
- 不能在初始值设定项列表中将非常量表达式从类型 'int' 缩小到'unsigned long long'
- 有没有什么方法可以使用一个函数中定义的常量变量,也可以由c++中同一程序中的其他函数使用
- 是默认情况下分配给char数组常量的值
- 私有类型的静态常量成员
- OpenGL大的3D纹理(>2GB)非常慢
- 类似枚举的计算常量
- 递归模板化函数不能分配给具有常量限定类型"const tt &"的变量"state"
- 使用常量键但非常量值进行映射
- 为什么`is_open()`非常常量
- 从getter方法返回常量和非常量值
- 阻止const类函数在引用成员上调用非常常量类函数
- C++初始化非常大的常量数组,最佳实践
- 提高c++中非常大的常量的可读性