如何寫好構(gòu)造函數(shù)
作者:王姍姍,華清遠(yuǎn)見嵌入式學(xué)院講師。
上課時(shí)大家都覺得構(gòu)造函數(shù)很難寫,在這我結(jié)合自己的理解,說說自己的幾點(diǎn)體會(huì):
首先我們得明確我們?yōu)槭裁葱枰獦?gòu)造函數(shù)。
在建立一個(gè)對(duì)象時(shí),常常需要做些初始化的工作,例如對(duì)數(shù)據(jù)成員賦初值。如果一個(gè)數(shù)據(jù)成員未被賦初值,則它的值是不可預(yù)知的,保留了這些存儲(chǔ)單元的原狀,這就成為了這些數(shù)據(jù)成員的初始值。而我們知道,類的數(shù)據(jù)成員時(shí)不能在聲明類時(shí)初始化的,因?yàn)轭惒⒉皇且粋€(gè)實(shí)體,而是一種抽象類型,并不占用存儲(chǔ)空間,無處容納數(shù)據(jù)。所以為了解決這個(gè)問題,C++提供了構(gòu)造函數(shù)來處理對(duì)象的初始化。構(gòu)造函數(shù)是一種特殊的成員函數(shù),它不需要用戶來調(diào)用它,在類對(duì)象進(jìn)入其作用域時(shí)由系統(tǒng)自動(dòng)調(diào)用。
其次,寫構(gòu)造函數(shù)的時(shí)候我們要注意幾點(diǎn):
1、構(gòu)造函數(shù)的名字必須與類的名字一樣,為了編譯系統(tǒng)能識(shí)別它。
2、它不具有任何類型,不返回任何值。
3、它的功能由用戶定義,用戶根據(jù)初始化的要求設(shè)計(jì)函數(shù)體和函數(shù)參數(shù)。
4、在構(gòu)造函數(shù)的函數(shù)體中,不僅可以對(duì)數(shù)據(jù)成員賦初值,而且可以包含其他語句。
5、如果用戶沒有定義構(gòu)造函數(shù),C++系統(tǒng)會(huì)自動(dòng)生成一個(gè)構(gòu)造函數(shù),只是這個(gè)構(gòu)造函數(shù)的函數(shù)體是空的, 沒有參數(shù),不執(zhí)行初始化操作。但一旦用戶寫了一個(gè)構(gòu)造函數(shù),系統(tǒng)將不在提供默認(rèn)構(gòu)造函數(shù)。
例如:
如果在類中增加一行
這個(gè)時(shí)候我們?cè)偃ゾ幾g,系統(tǒng)將報(bào)錯(cuò),原因就是在主函數(shù)第一行定義Time t ;時(shí)需要調(diào)用零個(gè)參數(shù)的構(gòu)造函數(shù),系統(tǒng)沒有提供,系統(tǒng)中只有三個(gè)參數(shù)的構(gòu)造函數(shù),故報(bào)錯(cuò)。
再次,在構(gòu)造函數(shù)中對(duì)各數(shù)據(jù)成員賦初值的方式也不盡相同。我們可以采用多種方式,例如:
1、帶參數(shù)的構(gòu)造函數(shù)。
帶參數(shù)的構(gòu)造函數(shù)中的形參,其對(duì)應(yīng)的實(shí)參在定義對(duì)象時(shí)給定。用這種方式可以方便地實(shí)現(xiàn)對(duì)不同的對(duì)象進(jìn)行不同的初始化。
2、用參數(shù)初始化表對(duì)數(shù)據(jù)成員初始化
這種方式就入上面加那句話
這里用h對(duì)hour賦值,m對(duì)minuete賦值,s對(duì)sec賦值。
在一個(gè)類中可以定義多個(gè)構(gòu)造函數(shù),也就是構(gòu)造函數(shù)可以重載的。我們通過不同的構(gòu)造函數(shù)可以使用不同的初始化方法來實(shí)現(xiàn)初始化。這些函數(shù)有相同的名字,而參數(shù)的個(gè)數(shù)或參數(shù)的類型不同。
例如:
在構(gòu)造函數(shù)中參數(shù)的值即可以通過實(shí)參傳遞,也可以指定為某些默認(rèn)值。也就是說如果用戶不指定實(shí)參值,編譯系統(tǒng)就使形參取默認(rèn)值。
例如:
Time(int h=0,int m=0,int s=0) :hour(h),minute(m),sec(s){};
這種情況下無論你給出幾個(gè)實(shí)參(0<=i<=3),都能調(diào)用上面的構(gòu)造函數(shù)。必須要強(qiáng)調(diào)的是,當(dāng)我們采用這種方式,即全部是默認(rèn)參數(shù)的構(gòu)造函數(shù)后,不能再定義重載構(gòu)造函數(shù)。
例如在上面定義完后,如果我們給出一個(gè)構(gòu)造函數(shù)如下:
這個(gè)時(shí)候main函數(shù)中有一個(gè)定義:
這個(gè)時(shí)候該執(zhí)行哪個(gè)構(gòu)造函數(shù)就出現(xiàn)了歧義,所以不應(yīng)同時(shí)使用構(gòu)造函數(shù)的重載和有默認(rèn)參數(shù)的構(gòu)造函數(shù)。
其實(shí)往往書寫起構(gòu)造函數(shù)時(shí)比理解什么時(shí)候系統(tǒng)為我們實(shí)例化對(duì)象時(shí)調(diào)用哪個(gè)構(gòu)造函數(shù)簡單的多,如果你寫程序報(bào)錯(cuò),我想應(yīng)該更多的去尋找下是否你在寫構(gòu)造函數(shù)的情況下提供了系統(tǒng)需要的那種構(gòu)造函數(shù)。
所以這個(gè)時(shí)候分析程序,知道要調(diào)用哪個(gè)構(gòu)造函數(shù)更重要,這里給出了例子,僅用來舉例分析下。這是在重載運(yùn)算符時(shí)寫的一個(gè)函數(shù),已經(jīng)把++前置函數(shù)寫完了;
都是為了實(shí)現(xiàn)創(chuàng)建old對(duì)象,同時(shí)對(duì)old賦值。不同的是:
Time ld=*this這種方式使用的是用無參的構(gòu)造函數(shù)構(gòu)造old對(duì)象,然后對(duì)其賦值
Time old(*this)這種方式使用的是調(diào)用拷貝構(gòu)造函數(shù),用this對(duì)象去構(gòu)造old對(duì)象
故如果系統(tǒng)中沒有提供Time(){}則系統(tǒng)將會(huì)報(bào)錯(cuò),所以在主函數(shù)中使用的時(shí)候還是要注意的,我們到底要選用哪種構(gòu)造函數(shù)形式
“本文由華清遠(yuǎn)見http://www.embedu.org/index.htm提供”
華清遠(yuǎn)見