- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
成员初始化顺序
C++
有如下几条:
1构造函数初始化列表的变量优先于构造函数(至少明显的写在前面) ?(若都在初始化列表中初始化,则按声明顺序初始化,与初始化列表中的顺序无关)
2静态成员变量先于实例变量
3父类成员变量先于子类成员变量
4父类构造函数先于子类构造函数
java和C#语言
1?? 类成员变量初始化先于类的构造函数
2?? 静态成员变量先于实例变量
3?? 父类成员变量先于子类成员变量 (C#相反)
4?? 父类构造函数先于子类构造函数
认识成员初始化列表(转载)
?一、?? 成员初始化列表的位置。
成员初始化列表的位置位于构造函数的函数体和参数表之间。
通过成员初始化表,类数据成员可以被显式初始化。成员初始化表是由逗号分隔的成员/名字实参对。例如下面的双参数构造函数的实现就使用了成员初始化表。_name是string 型的成员类对象。
1inline???Account::Account(?const?char*?name,?double?opening_bal?)2???????:?_name(?name?),?_balance(?opening_bal?)34{????????5???????_acct_nmbr?=?get_unique_acct_nmbr();????6}?
成员初始化表跟在构造函数的原型后,由冒号开头。成员名是被指定的。后面是括在括号中的初始值,类似于函数调用的语法。如果成员是类对象则初始值变成被传递给适当的构造函数的实参。该构造函数然后被应用在成员类对象上。在我们的例子中,name 被传递给应用在_name 上的string 构造函数。_balance 用参数opening_bal 初始化。
说明: 在这种情况下,string 的拷贝构造函数被调用。把成员类对象_name 初始化成string 参数name.
?
二、?? 使用初始化表和在构造函数内使用数据成员的赋值之间有什么区别?
?
inline Account::Account( const char *name, double opening_bal )
?????? : _name( name ), _balance( opening_bal )
{?????
?????? _acct_nmbr = get_unique_acct_nmbr();???
}
inline Account::Account( const char *name, double opening_bal )?{??????? _name = name;??????? _balance = opening_bal;??????? _acct_nmbr = get_unique_acct_nmbr();?}
这两种实现有区别吗?两种实现的最终结果是一样的。在两个构造函数调用的结束处三个成员都含有相同的值。区别是成员初始化表只提供该类数据成员的初始化。在构造函数体内对数据成员设置值是一个赋值操作。我们可以认为构造函数的执行过程被分成两个阶段:隐式或显式初始化阶段以及一般的计算阶段。计算阶段由构造函数体内的所有语句构成,在计算阶段中数据成员的设置被认为是赋值而不是初始化。没有清楚地认识到这个区别是程序错误和低效的常见源泉.
初始化阶段可以是显式的或隐式的取决于是否存在成员初始化表。隐式初始化阶段按照声明的顺序依次调用所有基类的缺省构造函数然后是所有成员类对象的缺省构造函数。
1?inline?Account::Account()2?{3?????????_name?=?;4?????????_balance?=?0.0;5?????????_acct_nmbr?=?0;6?}?
则初始化阶段是隐式的。在构造函数体被执行之前先调用与_name 相关联的缺省string构造函数。这意味着把空串赋给_name 的赋值操作是没有必要的。对于类对象,在初始化和赋值之间的区别是巨大的。成员类对象应该总是在成员初始化表中被初始化而不是在构造函数体内被赋值。
缺省Account 构造函数的更正确的实现如下:
inline Account::Account() : _name( string() )?{??????? _balance = 0.0;??????? _acct_nmbr = 0;?}
它之所以更正确,是因为我们已经去掉了在构造函数体内不必要的对_name 的赋值。但是对于缺省构造函数的显式调用也是不必要的。下面是更紧凑但却等价的实现:
inline Account::Account()?{?????? _balance = 0.0;?????? _acct_nmbr = 0;?}?剩下的问题是:
原创力文档


文档评论(0)