copy构造函数调用情况

很早知道拷贝构造函数被调用有三种情况:

1)类对象初始化该类的另一对象时;

2)形参为类对象的函数被调用时;

3)返回值为类对象的函数执行完成返回调用者时。

但今天才发现理解的和实际情况有偏差,并不是出现赋值运算符=就是调用的赋值操作运算符函数啊,比如这里的1),类对象初始化另一对象时是可以用拷贝构造函数形式,也可以利用赋值符号的形式啊,类似内置类型的初始化,用一个简单的类来验证了该事实。

#include <iostream>
#include <string>

using namespace std;


int main()
{
    class Foo{
    public:
        Foo()
        {
            myFun("This is from default constructor--Build-in type is not initialized!");
        }
        Foo(const Foo& rhs)
        {
            this->a = rhs.a+1;
            this->s = rhs.s;
            myFun("This is from copy constructor");
        }
        Foo& operator=(const Foo& rhs)
        {
            this->a = rhs.a+2;
            this->s = rhs.s;
            myFun("This is from  =operator");
            return *this;
        }
        Foo(int aa, string ss):a(aa),s(ss)
        {
            myFun("This is from constructor with Constructor Initializer List");
        }
        ~Foo(){}
        void myFun(string str)
        {
            cout << a << ends << s << endl << str << endl;
        }
    private:
        int a;
        string s;


    };
    Foo foo(3,"good");
    Foo foo1;//初始化
    Foo foo2=foo;
    Foo foo3(foo);


    foo1=foo;//这才是赋值
    return 0;
}
运行结果:

从结果可以看出只有最后一句才是来自赋值运算符,其上两个来自拷贝构造函数。

### C++ 中拷贝构造函数与基类构造函数调用顺序 #### 拷贝构造函数的工作原理 当创建一个对象作为另一个已存在对象的副本时,C++ 使用拷贝构造函数来初始化新对象。对于派生类而言,在其拷贝构造函数执行期间,不仅需要复制自身的成员变量,还需要确保正确地初始化来自基类的部分。 #### 基类构造函数的自动调用 如果派生类未显式提供自己的拷贝构造函数,则编译器会自动生成一个默认版本[^1]。此默认实现将负责调用相应的基类拷贝构造函数以及逐个字段地复制非静态数据成员。然而,一旦程序员定义了自己的拷贝构造函数,那么就必须手动处理这些细节——即显式调用合适的基类构造函数并完成必要的深拷贝操作[^2]。 #### 完整的例子展示调用过程 下面给出一段简单的代码片段用于说明上述概念: ```cpp #include <iostream> using namespace std; class Base { public: int b; // 显式的带参构造函数 Base(int val):b(val){ cout << "Base constructor called." << endl; } // 自定义的拷贝构造函数 Base(const Base &other) : b(other.b) { cout << "Base copy constructor called." << endl; } }; class Derived : public Base { private: double d; public: // 如果不指定如何调用父类构造函数, 编译器尝试寻找无参数版 // 这里指定了使用带有int参数的构造方法 Derived(double dd,int bb) : Base(bb),d(dd){ cout << "Derived constructor called." << endl; } // 用户定义的拷贝构造函数 Derived(const Derived &obj) : Base(obj), d(obj.d) { cout << "Derived copy constructor called." << endl; } }; int main(){ Derived obj1(3.14, 9); Derived obj2 = obj1; // 触发拷贝构造 return 0; } ``` 这段程序展示了两个重要方面: - 当实例化 `obj1` 时,首先是 `Base` 类型部分被构建(通过传递给它的整数值),接着才是整个 `Derived` 对象。 - 创建 `obj2` 并将其初始化为 `obj1` 的副本时,先是触发了 `Base` 的拷贝构造函数,随后才轮到 `Derived` 的拷贝构造函数工作。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值