关于拷贝构造函数的疑问

拷贝构造函数是通过引用传递,那岂不是意味着拷贝构造出来的对象和拷贝的对象是同一个地址?为什么我之后修改这两个对象的参数的时候发现并不是这样?

在C++中,拷贝构造函数通过引用传递的是对象的地址(指针),而不是对象本身。当你使用拷贝构造函数创建一个新的对象时,它会创建一个与原始对象相似的新对象,并且这个新对象拥有自己独立的内存空间。

虽然拷贝构造出来的对象和拷贝前的对象具有相同的值和成员,但它们位于不同的内存地址上,彼此独立。因此,修改一个对象并不会影响另一个对象的值。

简单来说,C++中通过拷贝构造函数拷贝出的是一个新对象,这个新对象与原对象是两个不同的对象,它们在内存中的位置是不同的。

不知道你这个问题是否已经解决, 如果还没有解决的话:
  • 这有个类似的问题, 你可以参考下: https://ask.csdn.net/questions/200252
  • 这篇博客也不错, 你可以看下为什么拷贝构造函数的参数可以直接去访问它自己的私有成员?关于对象不能直接访问私有成员的超级大误区~
  • 除此之外, 这篇博客: 拷贝构造函数为什么要用引用传参?中的 拷贝构造函数为什么要用引用传参? 部分也许能够解决你的问题, 你可以仔细阅读以下内容或者直接跳转源博客中阅读:

    拷贝构造函数是类的六个默认成员函数之一,他是构造函数的一个重载形式,其参数只有一个且必须要引用传递,那我们不禁想问值传递可以嘛?
    下面是一个拷贝构造函数的代码,让我们来分析下:

    Date(const Date d)
    	{
    		_year = d._year;
    		_month = d._month;
    		_day = d._day;
    
    		cout << "Date(Date&):" << this << endl;
    	}
    ...
    ...
    int main()
    {
    	Date d1(2020, 10, 12);
    	Date d2(d1);
    }
    

    当用已存在的对象创建新对象时候,编译器会自动调用拷贝构造函数完成新对象的初始化操作。
    假设该代码是成立,在值传递时候,传参期间会产生一个临时变量,当我们实例化对象d1后,将d1拷贝给d2时调用拷贝构造函数,此时d1发生值传递,d1将值传递给临时对象dd1,而此时又要调用拷贝构造函数将d1的值传递给dd1,因为是值传递,一旦调用又要产生临时变量ddd1,将d1的值传递给临时变量ddd1,那么问题就很明显了,值传递,会进行形参实例化,类类型实例化,会再调用构造函数,就会一直调用,因此结果就是无穷递归

  • 您还可以看一下 张传波老师的软件设计是怎样炼成的?课程中的 整个程序需要考虑的设计规范小节, 巩固相关知识点

如果你已经解决了该问题, 非常希望你能够分享一下解决方案, 写成博客, 将相关链接放在评论区, 以帮助更多的人 ^-^