聽侯捷老師的講課筆記:
所謂轉換函數指的是類型之間的轉換,比如把自定義的類類型轉換成內建類型(比如double),后者向相反的方向轉。
直接上代碼:
頭文件conversion_function.h:

#pragma once #include<iostream> using namespace std; class Fraction { public: Fraction(int num,int den=1):m_numerator(num),m_denominator(den) { cout << "構造函數 被調用了哦!!!" << endl; } ~Fraction(){ cout << "析構 函數被調用了哦!!!" << endl; } operator double()const { return (double)(m_numerator / m_denominator); } private: double m_numerator; double m_denominator; };
源文件conversion_function.cpp:

#include"conversion_function.h" int main() { Fraction f(1, 5); cout << f.operator double() << endl; double d = 4 + f; cout <<"d: "<< d << endl; system("pause"); return 0; }
轉換函數進階:
頭文件conversion_function.h:

#pragma once #include<iostream> using namespace std; class Fraction { public: /*加上關鍵字explicit就代表告訴編譯器說:你不要把double d2=f+4;這里面的4轉換成Fraction哦! 我寫的構造函數就只是為了構造對象,不用來充當轉換函數的作用。注:關鍵字explicit%90多的幾率 是加在構造函數的前面*/ explicit Fraction(int num, int den = 1) :m_numerator(num), m_denominator(den) { cout << "構造函數 被調用了哦!!!" << endl; } operator double() const { return double(this->m_numerator / this->m_denominator); } double operator +(const Fraction& f){ cout << "+號重載函數 被調用了哦!!!" << endl; return (this->m_numerator/this->m_denominator+f.m_numerator/f.m_denominator); } ~Fraction() { cout << "析構 函數被調用了哦!!!" << endl; } private: double m_numerator; double m_denominator; };
源文件conversion_function.cpp:

#include"conversion_function.h" int main() { Fraction f(3,5); double d2=f+4; cout << "d2: " << d2 << endl; system("pause"); return 0; }