轉(zhuǎn)換函數(shù)
轉(zhuǎn)換函數(shù)是用戶定義的強(qiáng)制類型轉(zhuǎn)換,如果定義了從MyClass到int的轉(zhuǎn)換函數(shù),就可以使用下面的轉(zhuǎn)換:
MyClass a;
int b = a;
創(chuàng)建轉(zhuǎn)換函數(shù)的形式:
operator typeName();
typeName指出了要轉(zhuǎn)換成的類型,因此不需要返回值。轉(zhuǎn)換函數(shù)是類方法意味著它需要通過類對象來調(diào)用,從而告知函數(shù)要轉(zhuǎn)換的值。因此,函數(shù)不需要參數(shù)。
注意三點(diǎn):1 轉(zhuǎn)換函數(shù)必須是類方法。2 轉(zhuǎn)換函數(shù)不能返回指定類型。3 轉(zhuǎn)換函數(shù)不能有參數(shù)。
例子中,轉(zhuǎn)換為int類型的類轉(zhuǎn)換函數(shù)原型為:operator int();
MyClass::operator int()
{
return ......;
}
explicit關(guān)鍵字
class Fraction
{
public:
explicit Fraction(int num, int den=1)
: m_numerator(num), m_denominator(den)
{ ?}
operator double() const {
return (double)m_numerator / m_denominator;
}
private:
int m_numerator; ? ?
int m_denominator; ?
};
例中構(gòu)造函數(shù)聲明中加入關(guān)鍵字explicit,如下
explicit Fraction(int num, int den=1): m_numerator(num), m_denominator(den){ ?}
那么
?Fraction f(3,5);
Fraction d2 = f + 4;這條語句將不能通過編譯。
在大部分情況中,隱式轉(zhuǎn)換卻容易導(dǎo)致錯誤(不是語法錯誤,編譯器不會報(bào)錯)。隱式轉(zhuǎn)換總是在我們沒有察覺的情況下悄悄發(fā)生,除非有心所為,隱式轉(zhuǎn)換常常是我們所不希望發(fā)生的。通過將構(gòu)造函數(shù)聲明為explicit(顯式)的方式可以抑制隱式轉(zhuǎn)換。也就是說,explicit構(gòu)造函數(shù)必須顯式調(diào)用。
智能指針
由于C++語言沒有自動內(nèi)存回收機(jī)制,每次new出來的內(nèi)存都要手動delete。有時(shí)候忘記delete,或者流程太復(fù)雜,最終導(dǎo)致沒有delete,或者由于異常導(dǎo)致程序過早退出而沒有執(zhí)行delete的情況并不罕見。用智能指針便可以有效緩解這類問題。
STL中提供的auto_ptr、unique_ptr、shared_ptr,其中模板auto_ptr是C++98提供的解決方案,C+11已將將其摒棄,并提供了前面另外兩種解決方案。然而,雖然auto_ptr被摒棄,但它已使用了好多年,同時(shí),如果您的編譯器不支持其他兩種解決力案,auto_ptr將是唯一的選擇。
這三個智能指針模板都定義了類似指針的對象,可以將new獲得的地址賦給這種對象。當(dāng)智能指針過期時(shí),其析構(gòu)函數(shù)將使用delete來釋放內(nèi)存。因此,如果將new返回的地址賦給這些對象,將無需記住稍后釋放這些內(nèi)存:在智能指針過期時(shí),這些內(nèi)存將自動被釋放。
為什么摒棄auto_ptr而需要其他智能指針?
先來看下面的賦值語句:
auto_ptr<String>??ps ?(new string("I reigned lonely as a cloud.”));
auto_ptr<String>?vocation;
vocaticn = ps;
上述賦值語句將完成什么工作呢?如果ps和vocation是常規(guī)指針,則兩個指針將指向同一個string對象。這是不能接受的,因?yàn)槌绦驅(qū)⒃噲D刪除同一個對象兩次——一次是ps過期時(shí),另一次是vocation過期時(shí)。要避免這種問題,方法有多種:
1.定義陚值運(yùn)算符,使之執(zhí)行深復(fù)制。這樣兩個指針將指向不同的對象,其中的一個對象是另一個對象的副本,缺點(diǎn)是浪費(fèi)空間,所以智能指針都未采用此方案。
2.建立所有權(quán)(ownership)概念。對于特定的對象,只能有一個智能指針可擁有,這樣只有擁有對象的智能指針的構(gòu)造函數(shù)會刪除該對象。然后讓賦值操作轉(zhuǎn)讓所有權(quán)。這就是用于auto_ptr和uniqiie_ptr 的策略,但unique_ptr的策略更嚴(yán)格。
3.創(chuàng)建智能更高的指針,跟蹤引用特定對象的智能指針數(shù)。這稱為引用計(jì)數(shù)。例如,賦值時(shí),計(jì)數(shù)將加1,而指針過期時(shí),計(jì)數(shù)將減1。僅當(dāng)最后一個指針過期時(shí)才調(diào)用delete。這是shared_ptr采用的策略。