C++類構(gòu)造函數(shù)初始化列表 構(gòu)造函數(shù)初始化列表以一個冒號開始,接著是以逗號分隔的數(shù)據(jù)成員列表,每個數(shù)據(jù)成員后面跟一個放在括號中的初始化式。
C++類構(gòu)造函數(shù)函數(shù)內(nèi)賦值 構(gòu)造函數(shù)函數(shù)內(nèi)賦值是在函數(shù)體內(nèi)將參數(shù)的值逐個賦值給類的成員變量。例
class CExample {public: int a; float b; //構(gòu)造函數(shù)初始化列表 CExample(): a(0),b(8.8) {} //構(gòu)造函數(shù)內(nèi)部賦值 CExample() { a=0; b=8.8; }};上面的例子中兩個構(gòu)造函數(shù)的結(jié)果是一樣的。上面的構(gòu)造函數(shù)(使用初始化列表的構(gòu)造函數(shù))顯式的初始化類的成員;而沒使用初始化列表的構(gòu)造函數(shù)是對類的成員賦值,并沒有進行顯式的初始化。
初始化和賦值對內(nèi)置類型的成員沒有什么大的區(qū)別,像上面的任一個構(gòu)造函數(shù)都可以。對非內(nèi)置類型成員變量,為了避免兩次構(gòu)造,推薦使用類構(gòu)造函數(shù)初始化列表。但有的時候必須用帶有初始化列表的構(gòu)造函數(shù): 1.成員類型是沒有默認構(gòu)造函數(shù)的類。若沒有提供顯示初始化式,則編譯器隱式使用成員類型的默認構(gòu)造函數(shù),若類沒有默認構(gòu)造函數(shù),則編譯器嘗試使用默認構(gòu)造函數(shù)將會失敗。 2.const成員或引用類型的成員。因為const對象或引用類型只能初始化,不能對他們賦值。
初始化數(shù)據(jù)成員與對數(shù)據(jù)成員賦值的含義是什么?有什么區(qū)別? 首先把數(shù)據(jù)成員按類型分類并分情況說明: 1.內(nèi)置數(shù)據(jù)類型,復合類型(指針,引用) 在成員初始化列表和構(gòu)造函數(shù)體內(nèi)進行,在性能和結(jié)果上都是一樣的 2.用戶定義類型(類類型) 結(jié)果上相同,但是性能上存在很大的差別。因為類類型的數(shù)據(jù)成員對象在進入函數(shù)體前已經(jīng)構(gòu)造完成,也就是說在成員初始化列表處進行構(gòu)造對象的工作,調(diào)用構(gòu)造函數(shù),在進入函數(shù)體之后,進行的是對已經(jīng)構(gòu)造好的類對象的賦值,又調(diào)用個拷貝賦值操作符才能完成(如果并未提供,則使用編譯器提供的默認按成員賦值行為)
請看下面這段代碼
“`
using namespace std;
class student { public: student() { };
student(student&s){ m_age = s.m_age; m_name = s.m_name;};student(int age,char* name):m_age(age),m_name(name){};~student() {};public: int m_age; char* m_name; };
class MyClass { public: MyClass(); MyClass(int a, char* p, student s); ~MyClass();
public: int m_a; char* m_str; student m_student; };
MyClass::MyClass() { cout << “默認構(gòu)造函數(shù)被調(diào)用” << endl; }
//MyClass::MyClass(int a, char* p,student s) //{ // m_a = a; // m_str = p; // m_student.m_age = s.m_age; // m_student.m_name = s.m_name; // cout << “我是重載構(gòu)造函數(shù)” << endl; //}
MyClass::MyClass(int a, char* p,student s) :m_a(a) ,m_str(p),m_student(s) { cout << “我是重載構(gòu)造函數(shù)2” << endl; }
MyClass::~MyClass() { }
int main() { student s(20, “李四”); MyClass obj(10, “123”,s);
return 0;}
“ 當在main函數(shù)中給對象obj初始化時,如果使用被注釋的MyClass類的函數(shù)體內(nèi)逐個賦值的方式則會調(diào)用student類的默認構(gòu)造函數(shù),但是如果使用MyClass類的初始化列表的方式,那么就不會調(diào)用student類的默認構(gòu)造函數(shù),如果student類有拷貝構(gòu)造函數(shù)的話,他會調(diào)用student類的拷貝構(gòu)造函數(shù),這時反而初始化列表的方式效率會低一些。
|
新聞熱點
疑難解答