對(duì)于成員初始化列表,熟悉有不是很熟悉。什么情況下使用呢?心里還是發(fā)怵,說(shuō)不出所以然來(lái)。
學(xué)習(xí)是王道,搜索是方法。有了網(wǎng)絡(luò)就是好。
摘自:
http://www.cnblogs.com/heyutao/archive/2009/05/22/1487081.html成員初始化列表 類對(duì)象的構(gòu)造順序是這樣的:
1.分配內(nèi)存,調(diào)用構(gòu)造函數(shù)時(shí),隱式/顯示的初始化各數(shù)據(jù)成員
初始化階段可以是顯式的或隱式的,取決于是否存在成員初始化表。隱式初始化階段按照聲明的順序依次調(diào)用所有基類的缺省構(gòu)造函數(shù),然后是所有成員類對(duì)象的缺省構(gòu)造函數(shù)。
2.進(jìn)入構(gòu)造函數(shù)后在構(gòu)造函數(shù)中執(zhí)行一般計(jì)算
計(jì)算階段由構(gòu)造函數(shù)體內(nèi)的所有語(yǔ)句構(gòu)成。在計(jì)算階段中,數(shù)據(jù)成員的設(shè)置被認(rèn)為是賦值,而不是初始化。
使用初始化列表有兩個(gè)原因:
1.必須這樣做:
三種情況下需要使用初始化成員列表
1)對(duì)象成員;
2)const修飾的成員;
3)引用成員數(shù)據(jù);
(1)如果有一個(gè)類成員,它本身是一個(gè)類或者是一個(gè)結(jié)構(gòu),而且這個(gè)成員它只有一個(gè)帶參數(shù)的構(gòu)造函數(shù),而沒(méi)有默認(rèn)構(gòu)造函數(shù),這時(shí)要對(duì)這個(gè)類成員進(jìn)行初始化,就必須調(diào)用這個(gè)類成員的帶參數(shù)的構(gòu)造函數(shù),如果沒(méi)有初始化列表,那么他將無(wú)法完成第一步,就會(huì)報(bào)錯(cuò)。
using namespace std;
class ABC


{
public:

ABC(int x,int y,int z):a(x),b(y),c(z)
{};
private:
int a;
int b;
int c;
};
class MyClass


{
public:

MyClass(int a,int b,int c):abc(a,b,c)
{}
private:
ABC abc;
};

int main()


{
MyClass o(1,2,3);
return 0;
}
(2)當(dāng)類成員中含有一個(gè)const成員時(shí)
(3)當(dāng)類成員中含有一個(gè)引用時(shí)
#include<iostream>
using namespace std;


class ConstRef
{
public:
ConstRef(int i);
void print();
private:
int a;
const int b;//const成員
int &c;//引用
};

ConstRef::ConstRef(int i):b(i),c(a)//含有一個(gè)const對(duì)象時(shí),或者是一個(gè)引用時(shí)使用初始化成員列表


{
a = i; // ok
//b = i; // 錯(cuò)誤
//c = a; // 錯(cuò)誤
}
void ConstRef::print()


{
cout<<a<<endl;
cout<<b<<endl;
cout<<c<<endl;
}
int main()


{
ConstRef o(1);
o.print();
return 0;
}
2.效率要求這樣做:
類對(duì)象的構(gòu)造順序顯示,進(jìn)入構(gòu)造函數(shù)體后,進(jìn)行的是計(jì)算,是對(duì)他們的賦值操作,顯然,賦值和初始化是不同的,這樣就體現(xiàn)出了效率差異,如果不用成員初始化列表,那么類對(duì)自己的類成員分別進(jìn)行的是一次隱式的默認(rèn)構(gòu)造函數(shù)的調(diào)用,和一次復(fù)制操作符的調(diào)用,如果是類對(duì)象,這樣做效率就得不到保障。
注意:構(gòu)造函數(shù)需要初始化的數(shù)據(jù)成員,不論是否顯式的出現(xiàn)在構(gòu)造函數(shù)的成員初始化列表中,都會(huì)在該處完成初始化,并且初始化的順序和其在聲明時(shí)的順序是一致的,與列表的先后順序無(wú)關(guān),所以要特別注意,保證兩者順序一致才能真正保證其效率。
現(xiàn)在明白為什么要使用成員初始化列表了。
這里再?gòu)?qiáng)調(diào)一下類的初始化的順序,應(yīng)該是類成員變量的初始化不是按照初始化表的順序被初始化的,而是按照在類中聲明的順序被初始化的。
這是摘自:Effective C++學(xué)習(xí)筆記:初始化列表中成員列出的順序和它們?cè)陬愔新暶鞯捻樞蛳嗤?/font> http://www.shnenglu.com/xczhang/archive/2008/01/22/41613.html
為什么會(huì)這樣呢?我們知道,對(duì)一個(gè)對(duì)象的所有成員來(lái)說(shuō),它們的析構(gòu)函數(shù)被調(diào)用的順序總是和它們?cè)跇?gòu)造函數(shù)里被創(chuàng)建的順序相反。那么,如果允許上面的情況(即,成員按它們?cè)诔跏蓟斜砩铣霈F(xiàn)的順序被初始化)發(fā)生,編譯器就要為每一個(gè)對(duì)象跟蹤其成員初始化的順序,以保證它們的析構(gòu)函數(shù)以正確的順序被調(diào)用。這會(huì)帶來(lái)昂貴的開銷。所以,為了避免這一開銷,同一種類型的所有對(duì)象在創(chuàng)建(構(gòu)造)和摧毀(析構(gòu))過(guò)程中對(duì)成員的處理順序都是相同的,而不管成員在初始化列表中的順序如何。
注意:上述內(nèi)容不適用于static變量,static變量應(yīng)該在類的構(gòu)造函數(shù)前被初始化。
好文章拿來(lái)學(xué)習(xí),請(qǐng)作者見(jiàn)諒哈!
posted on 2009-06-18 13:33
Sandy 閱讀(460)
評(píng)論(0) 編輯 收藏 引用 所屬分類:
c++學(xué)習(xí)