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++ 轉換函數用法內容請搜索html5模板網以前的文章希望大家以后多多支持html5模板網!
【網站聲明】本站部分內容來源于互聯網,旨在幫助大家更快的解決問題,如果有圖片或者內容侵犯了您的權益,請聯系我們刪除處理,感謝您的支持!