C++ 构造函数初始化列表的好处

       C++ 类对像构造时,需要对类成员变量完成初始化赋值操作。使用初始化列表完成这步操作在性能上有益处。什么好处呢?摆道理显得不够彻底。看书不如做实验。让我们结合执行过程来查看。考虑如下示例代码:

Capture

       Derive 类构造函数两个 Base 类型的参数,分别赋给该类两个 Base 类型的成员变量 b1、b2,一个使用初始化列表,一个使用等于号赋值。输出结果如下:

1

       前两行输出是主函数前两行构造 b1、b2 对像时调用的带参构造函数。第三行是初始化列表构造 b1 时调用的复制构造函数。第四行调用了一次默认构造函数……第四行是哪儿来的?

       这里需要陈述一下“复制构造函数”和“赋值重载函数”之间的语义区别。复制构造函数嘛,顾名思议,是根据一个模子造一个复制品出来。而赋值重载函数则是将一个已存在的对像的数据导到另一个已存在的对像中。因此,执行赋值动作之前,左值对像必须“已存在”。而在 Derive 类构造完成之前,其成员 b2 是不存在的。类定义中的成员变量只是一个声明,并不实际存在。因此,在执行 this->b2 = base2 这句之前,程序必须先将 b2 使用默认构造函数生成,而后才可完成赋值动作。

       通过单步调试,走 Dessembly,可以看到,在输出复制构造函数信息之后,Derive 类的 b1 构造完成,b1.fck 值为 10,而在默认构造函数信息输出之后并执行 this->b2 = base2 语句之前,b2 构造完成,b2.fck 值为 0。由此证明上述过程。

       其实这个问题很老套了,为何在此强调呢?为了引出后面的问题。

C++构造函数初始化列表是一种在构造函数初始化类成员变量和基类构造函数的特殊语法。它以冒号(:)开始,后跟一个或多个初始化项,每个初始化项由成员变量名或基类名和构造参数列表组成,各项之间用逗号分隔。 构造函数初始化列表的主要优势如下: 1. 效率更高:对于成员变量的初始化,尤其是const成员变量或引用类型的成员,构造函数初始化列表是必须使用的。与在构造函数体内赋值相比,初始化列表直接调用构造函数或赋值运算符来初始化成员变量,避免了不必要的拷贝或赋值操作,提高了效率。 2. 避免空缺问题:当成员变量为const或引用类型时,它们必须在构造函数中被初始化,因为它们不能被赋值。此时,初始化列表是唯一选择。 3. 对象的成员如果是类对象,使用初始化列表可以直接调用相应类的构造函数进行初始化,而不需要先默认构造再赋值,从而提高效率。 使用示例: ```cpp class Base { public: int baseValue; Base(int b) : baseValue(b) {} // 基类构造函数使用初始化列表 }; class Derived : public Base { public: int derivedValue; Derived(int b, int d) : Base(b), derivedValue(d) {} // 继承自Base,并初始化Derived的成员变量 }; ``` 在这个例子中,Derived类的构造函数使用初始化列表先调用基类Base的构造函数初始化基类部分,再初始化自己特有的成员变量derivedValue。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值