C/C++ 通过初始化列表和构造函数内赋值初始化成员变量的区别

本文对比了成员变量初始化的两种方法:构造函数内赋值与初始化列表。强调了在某些情况下(如初始化const成员)必须使用初始化列表,并从效率角度分析了后者的优势。

一般我们进行成员变量初始化用两种方法

第一种是通过在构造函数内赋值

class Point
{
public:
 Point(){ _x = 0; _y = 0;};
 Point( int x, int y ){ _x = 0; _y = 0; }
private:
 int _x, _y;
};

第二种是使用初始化列表

  class Point
{
public:
 Point():_x(0),_y(0){};
 Point( int x, int y ):_x(x),_y(y){}
private:
 int _x, _y;
};

 

这两种用法是有区别的

一、在有些情况下,必须使用初始化列表。特别是const和引用数据成员被初始化时。

class Point
{
// 这个类的定义就要求使用初始化成员列表,因为const成员只能被初始化,不能被赋值
public:
 Point():_x(0),_y(0){};
 Point( int x, int y ):_x(x),_y(y){}
 //Point(){ _x = 0; _y = 0;}
 //Point( int x, int y ){ _x = 0; _y = 0; }
private:
 const int _x, _y;
};

 

二、是从效率方面来说的,对于内置类型或复合类型,差异不会太大,但对于非内置数据类型,差异还是很明显的

如我们再给Point类添加一个新的string类型的成员变量

class Point
{
 const int _x, _y;
 string _name;
};

 

构造函数内赋值进行初始化

Point( int x, int y, string name ){ _x = 0; _y = 0; _name = name; }

 

_name = name 这个表达式会调用string类的缺省构造函数一次,再调用Operator=函数进行赋值一次。所以需调用两次函数:一次构造,一次赋值

 

用初始化列表进行初始化

Point( int x, int y, string name ):_x(x),_y(y), _name(name){}  

_name会通过拷贝构造函数仅以一个函数调用的代码完成初始化

即使是一个很简单的string类型,不必要的函数调用也会造成很高的代价。随着类越来越大,越来越复杂,它们的构造函数也越来越大而复杂,那么对象创建的代价也越来越高,所以一般情况下建议使用初始化列表进行初始化,不但可以满足const和引用成员的初始化要求,还可以避免低效的初始化数据成员。

详细出处参考:http://www.itqun.net/content-detail/105800_2.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值