一道关于c++拷贝构造与=运算符的题目

本文深入解析了C++中类成员初始化与赋值操作的区别,通过实例展示了初始化列表、拷贝构造与普通赋值的区别,并详细解释了初始化与赋值的概念。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

class A { public: A() { printf(" A "); } ~A() { printf(" ~A "); } }; class B { public: B(A &a):_a(a) { printf(" B "); } ~B() { printf(" ~B "); } private: A _a; }; int main() { A a; B b(a); return 0; }

这样一段代码,输出结果是 A B ~B ~A ~A
分析如下:

1.A a;构造一个对象a,调用A类的无参构造函数,输出A

2.B b(a); 执行到构造函数初始化列表 B(A &a):_a(a),相当于直接调用拷贝构造函数来初始化(ps: 当一个对象需要通过另外一个对象进行初始化时,会调用拷贝构造,但是由于类A没有显式声明拷贝构造函数,系统会生成默认拷贝构造函数,只进行位拷贝)

所以不会调用A()构造函数,此时无输出。继续构造则输出 B

析构顺序与构造顺序完全逆序,为~B ~A ~A

若改为这样

class A { public: A() { printf(" A "); } ~A() { printf(" ~A "); } }; class B { public: B(A &a) { printf(" B "); _a=a; } ~B() { printf(" ~B "); } private: A _a; }; int main() { A a; B b(a); return 0; }

这里B的构造函数被改为

B(A &a)
{
printf(" B ");
_a=a;
}

结果为 A A B ~B ~A ~A
分析_a=a;这一步,此时是先构造一个A _a对象(会输出 A),然后再执行_a=a(由于没有重载A类的=运算符,直接进行位拷贝)

为何这个=号不会调用拷贝构造呢,因为此时不是对_a进行初始化,而是普通的赋值操作。

那么什么是初始化,什么又是赋值呢?

可以阅读下此博客:

http://blog.youkuaiyun.com/lzcx/archive/2006/03/10/620790.aspx

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值