为什么当类具有引用成员时C++编译器不删除复制构造函数
Why C++ compiler does not delete copy constructor when class has reference member?
C++编译器不会为具有引用成员的类提供默认的复制赋值运算符(以及其他一些方案也是如此(。原因是,如果提供了默认的复制赋值运算符,则源对象和目标对象的引用成员都引用同一副本。
但是,在相同的方案中提供了默认复制构造函数,这引入了与提供默认复制赋值运算符相同的问题。
提供默认复制构造函数的任何原因?
#include <iostream>
using namespace std;
class People{
public:
People(string name = ""):m_name(name){
}
string getName(){
return m_name;
}
void setName(string name){
m_name = name;
}
private:
string& m_name;//reference member
};
int main() {
People a("Erik");
People b(a);
a.setName("Tom");
cout << a.getName() << endl;//This prints "Tom"
cout << b.getName() << endl;//This prints "Tom"
//a = b; //Build error
return 0;
}
可以在
复制构造函数中初始化引用,以引用与另一个类实例中的引用相同的对象。但是一旦初始化,就不能重新分配引用以引用不同的对象;因此,赋值运算符无法维护类似于复制构造函数的语义。
您的示例m_name
引用绑定到构造函数的参数,当构造函数返回时,该参数超出范围,使引用悬而未决。之后对m_name
的任何使用都会表现出未定义的行为。您不应该根据该程序的行为得出任何结论。
为什么当类具有引用成员时C++编译器不删除复制构造函数?
因为引用是可复制的。
如果提供了默认的复制赋值运算符,则源对象和目标对象的引用成员都引用同一副本。
不。无法提供隐式复制赋值运算符,因为无法为引用指定引用另一个对象。
相关文章:
- C/C++编译器通常会删除重复的库吗
- 模板-模板参数推导:三个不同的编译器三种不同的行为
- Win32编译器选项和内存分配
- MSVC多行宏编译器错误
- 静态数据成员的问题-修复链接错误会导致编译器错误
- C++,我收到一个无法理解的编译器错误
- 在线编译器中的分段C++没有打印消息
- 如何解决gcc编译器优化导致的centos双编译器设置中的分段错误
- C/C++预处理器是否可以检测一些编译器选项
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- C++错误C2600:无法定义编译器生成的特殊成员函数(必须首先在类中声明)
- 我需要知道编译器如何在cpp中使用析构函数
- 编译器如何区分std::vector的构造函数
- CLANG 编译器 说:变量"PTR"可能未初始化
- 告诉c++编译器该参数没有别名
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 为什么所有C++编译器都会崩溃或挂起此代码
- 编译器如何在使用SFINAE的函数和标准函数之间确定两者是否可行
- 我收到同义重复编译器错误。我应该如何修复"类型"X"的参数与类型"X"的参数不兼容?
- 为什么C++编译器没有检测到正确声明的类?