- 重載<<操作符
要重新定義<<操作符,以便將它和cout一起用來(lái)顯示對(duì)象的內(nèi)容,請(qǐng)定義下面的友元操作符函數(shù):ostream?&?operator?<<?(ostream?&?os,const?c_name?&?obj)
{
os?<<?
;//?display?object?contents
return?os;
}
其中c_name是類名。如果該類提供了能夠返回所需內(nèi)容的公有方法,則可在操作符函數(shù)中使用這些方法,這樣便不會(huì)將他們?cè)O(shè)置為友元函數(shù)了。 - 轉(zhuǎn)換函數(shù)
要將單個(gè)值轉(zhuǎn)換為類類型,需要?jiǎng)?chuàng)建原型如下所示的類構(gòu)造函數(shù):c_name(type_name?value);
其中c_name為類名,type_name是要轉(zhuǎn)換的類型的名稱。
要將類轉(zhuǎn)換為其他類型,需要?jiǎng)?chuàng)建原型如下所示的類成員函數(shù):operator?type_name();
雖然該函數(shù)沒(méi)有聲明返回類型,但應(yīng)返回所需類型的值。
使用轉(zhuǎn)換函數(shù)時(shí)要小心??梢栽诼暶鳂?gòu)造函數(shù)時(shí)使用關(guān)鍵字explicit,以防止它被用于隱式轉(zhuǎn)換。 - 其構(gòu)造函數(shù)使用new的類
如果類使用new操作符來(lái)分配類成員指向的內(nèi)存,在設(shè)計(jì)時(shí)應(yīng)采取一些預(yù)防措施。
- 對(duì)于指向的內(nèi)存是由new分配的所有類成員,都應(yīng)在類的析構(gòu)函數(shù)中對(duì)其使用delete,該操作符將釋放分配的內(nèi)存。
- 如果析構(gòu)函數(shù)通過(guò)對(duì)指針類成員使用delete來(lái)釋放內(nèi)存,則每個(gè)構(gòu)造函數(shù)都應(yīng)當(dāng)使用new來(lái)初始化指針,或?qū)⑺O(shè)置為空指針。
- 構(gòu)造函數(shù)中要么使用new[],要么使用new,而不能混用。如果構(gòu)造函數(shù)使用的是new[],則析構(gòu)函數(shù)應(yīng)使用delete[];如果構(gòu)造函數(shù)使用的是new,則析構(gòu)函數(shù)應(yīng)適用delete。
- 應(yīng)定義一個(gè)分配內(nèi)存(而不是將指針指向已有內(nèi)存)的復(fù)制構(gòu)造函數(shù)。這樣程序能夠?qū)㈩悓?duì)象初始化為另一個(gè)對(duì)象。這種構(gòu)造函數(shù)原型如下:
className(const?className?&)
- 應(yīng)定義一個(gè)重載賦值操作符的類成員函數(shù),其函數(shù)定義如下(其中c_pointer是c_name的類成員,類型為指向type_name的指針)。下面的范例假設(shè)使用new[]來(lái)初始化變量c_pointer):
c_name?&?c_name::operator?=?(const?c_name?&?cn)
{
if?(this?==?&?cn)
return?*this;
delete?[]?c_pointer;
//?set?size?number?of?type_name?units?to?be?copyied
c_pointer?=?new?type_name[size];
//?then?copy?data?pointed?to?by?cn.c_pointer?to
//?location?pointed?to?by?c_pointer
return?*this;
}
本文對(duì)我前面幾篇隨筆中提到的問(wèn)題也作出了一個(gè)總結(jié),感覺(jué)很有必要記下來(lái)。
以上內(nèi)容原文引用自參考書(shū)籍中內(nèi)容。
參考書(shū)籍:C++PrimerPlus author:Stephen Prata