C++ 轉換函數用法案例詳解
1.標準數據之間會進行隱式類型安全轉換,規則如下:
在這裡主要探討c++中類類型與普通類型的轉換:
1.類類型轉換普通類型
class Fraction { public: Fraction(int num,int den=1); ~Fraction(); //轉換函數 /* 轉換函數語法規則: operator Type() { Type ret ; ........ return ret; } */ operator double() const { return (double)(m_Numerator*1.0 / m_Denominator); } private: int m_Numerator; int m_Denominator; }; Fraction f(3, 5); double d = 4 + f;//d=4.6
這裡4+f,調用轉換函數將f轉換為0.6
2.普通類型轉換為類類型(non-explicit-one-argument ctor)
class Fraction { public: Fraction(int num,int den=1); ~Fraction(); Fraction operator+(const Fraction& f) { return Fraction(this->m_Numerator * f.m_Denominator + this->m_Denominator * f.m_Numerator, f.m_Denominator * this->m_Denominator); } private: int m_Numerator; int m_Denominator; }; Fraction f(3, 5); Fraction d = f + 4;//調用+運算符函數,4會轉為Fraction(4,1),含有接受一個參數的構造函數,否則也無法轉換
3.同時含有轉換函數和可以隱式的調用構造函數(轉換構造參數)會報錯
class Fraction { public: /* 轉換構造函數: -有僅有一個參數 -參數是基本類型 -參數是其它類型 */ Fraction(int num,int den=1); ~Fraction(); operator double() const { return (double)(m_Numerator*1.0 / m_Denominator); } Fraction operator+(const Fraction& f) { return Fraction(this->m_Numerator * f.m_Denominator + this->m_Denominator * f.m_Numerator, f.m_Denominator * this->m_Denominator); } private: int m_Numerator; int m_Denominator; };
報錯: “Fraction::operator +”: 2 個重載有相似的轉換 ,
所以在我們寫構造函數都會使用關鍵字 explicit 防止類型隱式轉換
class Fraction { public: explicit Fraction(int num,int den=1); ~Fraction(); operator double() const { return (double)(m_Numerator*1.0 / m_Denominator); } Fraction operator+(const Fraction& f) { return Fraction(this->m_Numerator * f.m_Denominator + this->m_Denominator * f.m_Numerator, f.m_Denominator * this->m_Denominator); } private: int m_Numerator; int m_Denominator; }; Fraction f(3, 5); Fraction d = f + 4;//報錯:不存在從 "double" 轉換到 "Fraction" 的適當構造函數 double d = f + 4;//可以,f轉換
到此這篇關於C++ 轉換函數用法案例詳解的文章就介紹到這瞭,更多相關C++ 轉換函數用法內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!