| 導購 | 订阅 | 在线投稿
分享
 
 
當前位置: 王朝網路 >> c/c++ >> C++運算符重載轉換運算符
 

C++運算符重載轉換運算符

2008-06-01 02:07:18  編輯來源:互聯網  简体版  手機版  評論  字體: ||
 
 
  爲什麽需要轉換運算符? 大家知道對于內置類型的數據我們可以通過強制轉換符的使用來轉換數據,例如(int)2.1f;自定義類也是類型,那麽自定義類的對象在很多情況下也需要支持此操作,C++提供了轉換運算符重載函數,它使得自定義類對象的強轉換成爲可能。

  轉換運算符的生命方式比較非凡,方法如下:

  Operator 類名();

  轉換運算符的重載函數是沒有返回類型的,它和類的構造函數,析構函數一樣是不遵循函數有返回類型的規定的,他們都沒有返回值。

  下面我看一個例子,看看它是如何工作的:

  //例1

  

  //程序作者:管甯

  //站點:www.cndev-lab.com

  //所有稿件均有版權,如要轉載,請務必聞名出處和作者

  

  #include <iostream>

  using namespace std;

  

  class Test

  {

   public:

   Test(int a = 0)

   {

   cout<<this<<":"<<"載入構造函數!"<<a<<endl;

   Test::a = a;

   }

   Test(Test &temp)

   {

   cout<<"載入拷貝構造函數!"<<endl;

   Test::a = temp.a;

   }

   ~Test()

   {

   cout<<this<<":"<<"載入析構函數!"<<this->a<<endl;

   cin.get();

   }

   operator int()//轉換運算符

   {

   cout<<this<<":"<<"載入轉換運算符函數!"<<this->a<<endl;

   return Test::a;

   }

   public:

   int a;

  };

  int main()

  {

   Test b(99);

   cout<<"b的內存地址"<<&b<<endl;

   cout<<(int)b<<endl;//強轉換

  

   system("pause");

  }

  在例子中我們利用轉換運算符將Test類的對象強轉換成了int類型並輸出,注重觀察轉換運算符函數的運行狀態,發現並沒有産生臨時對象,證實了它與普通函數並不相同,雖然它帶有return語句。

  在很多情況下,類的強轉換運算符還可以作爲類對象加運算重載函數使用,盡管他們的意義並不相同,下面的例子,就是利用轉換運算符,將兩個類對象轉換成int後,相加並創建臨時類對象,後再賦給另一個對象。

  代碼如下://例2

  

  //程序作者:管甯

  //站點:www.cndev-lab.com

  //所有稿件均有版權,如要轉載,請務必聞名出處和作者

  

  #include <iostream>

  using namespace std;

  

  class Test

  {

   public:

   Test(int a = 0)

   {

   cout<<this<<":"<<"載入構造函數!"<<a<<endl;

   Test::a = a;

   }

   Test(Test &temp)

   {

   cout<<"載入拷貝構造函數!"<<endl;

   Test::a = temp.a;

   }

   ~Test()

   {

   cout<<this<<":"<<"載入析構函數!"<<this->a<<endl;

   cin.get();

   }

   operator int()

   {

   cout<<this<<":"<<"載入轉換運算符函數的內存地址:"<<this->a<<endl;

   return Test::a;

   }

   public:

   int a;

  };

  int main()

  {

   Test a(100),b(100),c;

   cout<<"a的內存地址"<<&a<<" b的內存地址"<<&b<<endl;

   c=Test((int)a+(int)b);//顯示式轉換

  

   //c=a+b;//隱式轉換

   cout<<"c的內存地址"<<&c<<endl;

   cout<<c.a<<endl;

   system("pause");

  }

  代碼中的c=a+b;屬于隱式轉換,它的實現過程與c=Test((int)a+(int)b);完全相同。

  運行結果如下圖示(注重觀察內存地址,觀察構造與析構過程,執行過程圖中有解釋):

C++運算符重載轉換運算符


  當一個類含有轉換運算符重載函數的時候,有時候會破壞C++原有規則,導致運算效率降低,這一點不得不注重。

  示例如下:

  //例3

  

  //程序作者:管甯

  //站點:www.cndev-lab.com

  //所有稿件均有版權,如要轉載,請務必聞名出處和作者

  

  #include <iostream>

  using namespace std;

  

  class Test

  {

   public:

   Test(int a = 0)

   {

   cout<<this<<":"<<"載入構造函數!"<<a<<endl;

   Test::a = a;

   }

   Test(Test &temp)

   {

   cout<<"載入拷貝構造函數!"<<endl;

   Test::a = temp.a;

   }

   ~Test()

   {

   cout<<this<<":"<<"載入析構函數!"<<this->a<<endl;

   cin.get();

   }

   operator int()//轉換運算符,去掉則不會調用

   {

   cout<<this<<":"<<"載入轉換運算符函數的內存地址:"<<this->a<<endl;

   return Test::a;

   }

   public:

   int a;

  };

  int main()

  

   {

   Test b=Test(99);//注重這裏

   cout<<"b的內存地址"<<&b<<endl;

   cout<<b.a<<endl;

   system("pause");

  }

  按照C++對無名對象的約定,Test b=Test(99);C++是會按照Test b(99);來處理的,可是由于轉換運算符的加入,導致這一規律被破壞,系統會「錯誤的」認爲你是要給對象賦值,所以系統首先利用Test(99)創建一個臨時對象用于賦值過程使用,可是恰恰系統又沒有使用自動提供的賦值運算重載函數去處理,因爲發現b對象並未構造,轉而又不得不將開始原本用于賦值而創建的臨時對象再次的強轉換爲int類型,提供給b對象進行構造,可見中間的創建臨時對象和載入轉換運算符函數的過程完全是多余,讀者對此例要認真解讀,充分理解。

  運行結果如下圖所示(運行過程的解釋見圖):

C++運算符重載轉換運算符


  由于類的轉換運算符與類的運算符重載函數,在某些地方上使用的時候,有功能相似的地方,假如兩者都存在于類中,那麽雖然運行結果正確,但其運行過程會出現一些意向不到的步驟,導致程序運行效率降低。

  下面的例子就是這個情況,代碼如下://例4

  

  //程序作者:管甯

  //站點:www.cndev-lab.com

  //所有稿件均有版權,如要轉載,請務必聞名出處和作者

  

  #include <iostream>

  using namespace std;

  

  class Test

  {

   public:

   Test(int a = 0)

   {

   cout<<this<<":"<<"載入構造函數!"<<a<<endl;

   Test::a = a;

   }

   Test(Test &temp)

   {

   cout<<"載入拷貝構造函數!"<<endl;

   Test::a = temp.a;

   }

   ~Test()

   {

   cout<<this<<":"<<"載入析構函數!"<<this->a<<endl;

   cin.get();

   }

   Test operator +(Test& temp2)

   {

   cout<<this<<""<<&temp2<<"載入加運算符重載函數!"<<endl;

  

   Test result(this->a+temp2.a);

   return result;

   }

   operator int()

   {

   cout<<this<<":"<<"載入轉換運算符函數的內存地址:"<<this->a<<endl;

   return Test::a;

   }

   public:

   int a;

  };

  int main()

  {

   Test a(100),b(100);

   cout<<"a的內存地址:"<<&a<<" b的內存地址:"<<&b<<endl;

   Test c=a+b;

   cout<<"c的內存地址:"<<&c<<endl;

   cout<<c.a<<endl;

   system("pause");

  }

  運行過程見下圖。

C++運算符重載轉換運算符


  從圖中我們可以清楚的看到,不必要的運算過程被執行,導致開銷增大,讀者在理解此例的時候要格外小心!

  現在總結一下轉換運算符的優點與缺點:

  優點:在不提供帶有類對象參數的運算符重載函數的情況下,轉換運算符重載函數可以將類對象轉換成需要的類型,然後進行運算,最後在構造成類對象,這一點和類的運算符重載函數有相同的功效。(例2就是這種情況)

  缺點:假如一個類只有轉換運算符重載函數,而沒有真正意義上運算符重載函數,當用轉換運算符重載函數替代運算符重載函數,進行工作的時候,就會讓程序的可讀性降低,歪曲了運算符操作的真正含義。(例2中的c=a+b;//隱式轉換,就是例子,事實上a+b的作用只是對返回的整型數據進行了加運算,而對象賦值的操作是系統隱式的幫大家轉換成了c=Test(a+b)。)

  最後我們來說一下,多路徑轉換的多義性問題,多義性問題一直是C++編程中輕易忽視的問題,但它的確是不容小視,當問題隱藏起來的時候你不會發覺,一旦觸發麻煩就來了。

  類的轉換構造函數與類的轉換運算符重載函數是互逆的。(例3中的Test(int a = 0)是將int類型的數據轉換構造成Test類對象,而operator int()則是將Test類對象轉換成int類型數據)

  但是當他們是出現在兩個不同的類中,對于一個類對象轉換來說,同時擁有兩種近似的轉換途徑的時候,多義性的問題就暴露出來,導致編譯出錯。

  下例就是這個狀態:

  //程序作者:管甯

  //站點:www.cndev-lab.com

  //所有稿件均有版權,如要轉載,請務必聞名出處和作者

  

  #include <iostream>

  using namespace std;

  class B;

  class A

  {

   public:

   A(B &);//轉換構造函數,他的作用是用B類對象構造A類對象

   void Edita(int temp)

   {

   A::a=temp;

   }

  

   public:

   int a;

  };

  class B

  {

   public:

   B(int a=0)

   {

   B::a=a;

   }

   int Ra()

   {

   return B::a;

   }

   operator A()//轉換運算符重載函數,他的作用則是將B類對象轉換成A類對象

   {

   return *this;

   }

   PRotected:

   int a;

  };

  A::A(B &temp)

  {

   cout<<this<<""<<&temp<<endl;

   A::a=temp.Ra();

  }

  void tp(A temp)

  {

  

  }

  int main()

  {

   B BT(100);

   A at=A(bt);

   //tp(bt);//錯誤,多義性問題,系統不知道如何選擇,是選擇A(B &)轉化構造好呢?還是選擇B::operator A()進行轉換好呢?

   tp(A::A(bt));//顯示的處理可以消除多義性問題

   system("pause");

  }

  代碼中的A at=A(bt);運行正常,因爲系統發現對象at還未構造,所以優先選取了A類的轉換構造函數處理了,沒有産生二義性問題。

  但是代碼中的tp(bt);編譯錯誤,這是因爲函數tp的參數要求的是一個A類對象,而我們給他的則是一個B類對象,而在A類與B類中都有一個類似的操作,可以將B類對象轉換成A類對象,系統不知道是選取A類的轉換構造函數進行構造處理,還是選擇B類中的轉換運算符號重載函數處理,系統拒絕從他們兩個中選一個,所以編譯錯誤。

  我們修改tp(bt)爲tp(A::A(bt));編譯正常,因爲我們顯式的明確的告訴系統應該使用A類的轉換構造函數處理,所以,顯式的告訴計算機應該如何處理數據,通常可以解決多義性問題。
 
 
 
上一篇《C++的iostream標准庫介紹(3)》
下一篇《C語言的常用庫函數使用方法分析及用途》
 
 
 
 
 
 
日版寵物情人插曲《Winding Road》歌詞

日版寵物情人2017的插曲,很帶節奏感,日語的,女生唱的。 最後聽見是在第8集的時候女主手割傷了,然後男主用嘴幫她吸了一下,插曲就出來了。 歌手:Def...

兄弟共妻,我成了他們夜裏的美食

老鍾家的兩個兒子很特別,就是跟其他的人不太一樣,魔一般的執著。兄弟倆都到了要結婚的年齡了,不管自家老爹怎麽磨破嘴皮子,兄弟倆說不娶就不娶,老父母爲兄弟兩操碎了心...

如何磨出破洞牛仔褲?牛仔褲怎麽剪破洞?

把牛仔褲磨出有線的破洞 1、具體工具就是磨腳石,下面墊一個硬物,然後用磨腳石一直磨一直磨,到把那塊磨薄了,用手撕開就好了。出來的洞啊很自然的。需要貓須的話調幾...

我就是掃描下圖得到了敬業福和愛國福

先來看下敬業福和愛國福 今年春節,支付寶再次推出了“五福紅包”活動,表示要“把欠大家的敬業福都還給大家”。 今天該活動正式啓動,和去年一樣,需要收集“五福”...

冰箱異味産生的原因和臭味去除的方法

有時候我們打開冰箱就會聞到一股異味,冰箱裏的這種異味是因爲一些物質發出的氣味的混合體,聞起來讓人惡心。 産生這些異味的主要原因有以下幾點。 1、很多人有這種習...

《極品家丁》1-31集大結局分集劇情介紹

簡介 《極品家丁》講述了現代白領林晚榮無意回到古代金陵,並追隨蕭二小姐化名“林三”進入蕭府,不料卻陰差陽錯上演了一出低級家丁拼搏上位的“林三升職記”。...

李溪芮《極品家丁》片尾曲《你就是我最愛的寶寶》歌詞

你就是我最愛的寶寶 - 李溪芮 (電視劇《極品家丁》片尾曲) 作詞:常馨內 作曲:常馨內 你的眉 又鬼馬的挑 你的嘴 又壞壞的笑 上一秒吵鬧 下...

烏梅的功效與作用以及烏梅的食用禁忌有哪些?

烏梅,又稱春梅,中醫認爲,烏梅味酸,性溫,無毒,具有安心、除熱、下氣、祛痰、止渴調中、殺蟲的功效,治肢體痛、肺痨病。烏梅泡水喝能治傷寒煩熱、止吐瀉,與幹姜一起制...

什麽是脂肪粒?如何消除臉部脂肪粒?

什麽是脂肪粒 在我們的臉上總會長一個個像脂肪的小顆粒,弄也弄不掉,而且顔色還是白白的。它既不是粉刺也不是其他的任何痘痘,它就是脂肪粒。 脂肪粒雖然也是由油脂...

網絡安全治理:國家安全保障的主要方向是打擊犯罪,而不是處置和懲罰受害者

來源:中國青年報 新的攻擊方法不斷湧現,黑客幾乎永遠占據網絡攻擊的上風,我們不可能通過技術手段杜絕網絡攻擊。國家安全保障的主要方向是打擊犯罪,而不是處置和懲罰...

河南夫妻在溫嶺網絡直播“造人”內容涉黃被刑事拘留

夫妻網絡直播“造人”爆紅   1月9日,溫嶺城北派出所接到南京警方的協查通告,他們近期打掉了一個涉黃直播APP平台。而根據掌握的線索,其中有一對涉案的夫妻主播...

如何防止牆紙老化?牆紙變舊變黃怎麽辦?

如何防止牆紙老化? (1)選擇透氣性好的牆紙 市場上牆紙的材質分無紡布的、木纖維的、PVC的、玻璃纖維基材的、布面的等,相對而言,PVC材質的牆紙最不透氣...

鮮肌之謎非日本生産VS鮮肌之謎假日貨是謠言

觀點一:破日本銷售量的“鮮肌之謎” 非日本生産 近一段時間,淘寶上架了一款名爲“鮮肌之謎的” 鲑魚卵巢美容液,號稱是最近日本的一款推出的全新護膚品,産品本身所...

中國最美古詩詞精選摘抄

系腰裙(北宋詞人 張先) 惜霜蟾照夜雲天,朦胧影、畫勾闌。人情縱似長情月,算一年年。又能得、幾番圓。 欲寄西江題葉字,流不到、五亭前。東池始有荷新綠,尚小如...

關于女人的經典語句

關于女人的經典語句1、【做一個獨立的女人】 思想獨立:有主見、有自己的人生觀、價值觀。有上進心,永遠不放棄自己的理想,做一份自己喜愛的事業,擁有快樂和成就...

未來我們可以和性愛機器人結婚嗎?

你想體驗機器人性愛嗎?你想和性愛機器人結婚嗎?如果你想,機器人有拒絕你的權利嗎? 近日,第二屆“國際人類-機器人性愛研討會”大會在倫敦金史密斯大學落下帷幕。而...

全球最變態的十個地方

10.土耳其地下洞穴城市 變態指數:★★☆☆☆ 這是土耳其卡帕多西亞的一個著名景點,傳說是當年基督教徒們爲了躲避戰爭而在此修建。裏面曾住著20000人,...

科學家稱,人類死亡後意識將在另外一個宇宙中繼續存活

據英國《每日快報》報道,一位科學家兼理論家Robert Lanza博士宣稱,世界上並不存在人類死亡,死亡的只是身體。他認爲我們的意識借助我們體內的能量生存,而且...

《屏裏狐》片頭曲《我愛狐狸精》歌詞是什麽?

《我愛狐狸精》 - 劉馨棋   (電視劇《屏裏狐》主題曲)   作詞:金十三&李旦   作曲:劉嘉   狐狸精 狐狸仙   千年修...

 
 
 
  爲什麽需要轉換運算符?  大家知道對于內置類型的數據我們可以通過強制轉換符的使用來轉換數據,例如(int)2.1f;自定義類也是類型,那麽自定義類的對象在很多情況下也需要支持此操作,C++提供了轉換運算符重載函數,它使得自定義類對象的強轉換成爲可能。  轉換運算符的生命方式比較非凡,方法如下:    Operator 類名();   轉換運算符的重載函數是沒有返回類型的,它和類的構造函數,析構函數一樣是不遵循函數有返回類型的規定的,他們都沒有返回值。   下面我看一個例子,看看它是如何工作的: //例1 //程序作者:管甯 //站點:www.cndev-lab.com //所有稿件均有版權,如要轉載,請務必聞名出處和作者 #include <iostream> using namespace std; class Test { public: Test(int a = 0) { cout<<this<<":"<<"載入構造函數!"<<a<<endl; Test::a = a; } Test(Test &temp) { cout<<"載入拷貝構造函數!"<<endl; Test::a = temp.a; } ~Test() { cout<<this<<":"<<"載入析構函數!"<<this->a<<endl; cin.get(); } operator int()//轉換運算符 { cout<<this<<":"<<"載入轉換運算符函數!"<<this->a<<endl; return Test::a; } public: int a; }; int main() { Test b(99); cout<<"b的內存地址"<<&b<<endl; cout<<(int)b<<endl;//強轉換 system("pause"); }   在例子中我們利用轉換運算符將Test類的對象強轉換成了int類型並輸出,注重觀察轉換運算符函數的運行狀態,發現並沒有産生臨時對象,證實了它與普通函數並不相同,雖然它帶有return語句。   在很多情況下,類的強轉換運算符還可以作爲類對象加運算重載函數使用,盡管他們的意義並不相同,下面的例子,就是利用轉換運算符,將兩個類對象轉換成int後,相加並創建臨時類對象,後再賦給另一個對象。   代碼如下://例2 //程序作者:管甯 //站點:www.cndev-lab.com //所有稿件均有版權,如要轉載,請務必聞名出處和作者 #include <iostream> using namespace std; class Test { public: Test(int a = 0) { cout<<this<<":"<<"載入構造函數!"<<a<<endl; Test::a = a; } Test(Test &temp) { cout<<"載入拷貝構造函數!"<<endl; Test::a = temp.a; } ~Test() { cout<<this<<":"<<"載入析構函數!"<<this->a<<endl; cin.get(); } operator int() { cout<<this<<":"<<"載入轉換運算符函數的內存地址:"<<this->a<<endl; return Test::a; } public: int a; }; int main() { Test a(100),b(100),c; cout<<"a的內存地址"<<&a<<" b的內存地址"<<&b<<endl; c=Test((int)a+(int)b);//顯示式轉換 //c=a+b;//隱式轉換 cout<<"c的內存地址"<<&c<<endl; cout<<c.a<<endl; system("pause"); }   代碼中的c=a+b;屬于隱式轉換,它的實現過程與c=Test((int)a+(int)b);完全相同。   運行結果如下圖示(注重觀察內存地址,觀察構造與析構過程,執行過程圖中有解釋): [url=/bbs/detail_1785399.html][img]http://image.wangchao.net.cn/it/1323423594100.gif[/img][/url]   當一個類含有轉換運算符重載函數的時候,有時候會破壞C++原有規則,導致運算效率降低,這一點不得不注重。   示例如下: //例3 //程序作者:管甯 //站點:www.cndev-lab.com //所有稿件均有版權,如要轉載,請務必聞名出處和作者 #include <iostream> using namespace std; class Test { public: Test(int a = 0) { cout<<this<<":"<<"載入構造函數!"<<a<<endl; Test::a = a; } Test(Test &temp) { cout<<"載入拷貝構造函數!"<<endl; Test::a = temp.a; } ~Test() { cout<<this<<":"<<"載入析構函數!"<<this->a<<endl; cin.get(); } operator int()//轉換運算符,去掉則不會調用 { cout<<this<<":"<<"載入轉換運算符函數的內存地址:"<<this->a<<endl; return Test::a; } public: int a; }; int main() { Test b=Test(99);//注重這裏 cout<<"b的內存地址"<<&b<<endl; cout<<b.a<<endl; system("pause"); }   按照C++對無名對象的約定,Test b=Test(99);C++是會按照Test b(99);來處理的,可是由于轉換運算符的加入,導致這一規律被破壞,系統會「錯誤的」認爲你是要給對象賦值,所以系統首先利用Test(99)創建一個臨時對象用于賦值過程使用,可是恰恰系統又沒有使用自動提供的賦值運算重載函數去處理,因爲發現b對象並未構造,轉而又不得不將開始原本用于賦值而創建的臨時對象再次的強轉換爲int類型,提供給b對象進行構造,可見中間的創建臨時對象和載入轉換運算符函數的過程完全是多余,讀者對此例要認真解讀,充分理解。   運行結果如下圖所示(運行過程的解釋見圖): [url=/bbs/detail_1785399.html][img]http://image.wangchao.net.cn/it/1323423594279.gif[/img][/url]   由于類的轉換運算符與類的運算符重載函數,在某些地方上使用的時候,有功能相似的地方,假如兩者都存在于類中,那麽雖然運行結果正確,但其運行過程會出現一些意向不到的步驟,導致程序運行效率降低。   下面的例子就是這個情況,代碼如下://例4 //程序作者:管甯 //站點:www.cndev-lab.com //所有稿件均有版權,如要轉載,請務必聞名出處和作者 #include <iostream> using namespace std; class Test { public: Test(int a = 0) { cout<<this<<":"<<"載入構造函數!"<<a<<endl; Test::a = a; } Test(Test &temp) { cout<<"載入拷貝構造函數!"<<endl; Test::a = temp.a; } ~Test() { cout<<this<<":"<<"載入析構函數!"<<this->a<<endl; cin.get(); } Test operator +(Test& temp2) { cout<<this<<""<<&temp2<<"載入加運算符重載函數!"<<endl; Test result(this->a+temp2.a); return result; } operator int() { cout<<this<<":"<<"載入轉換運算符函數的內存地址:"<<this->a<<endl; return Test::a; } public: int a; }; int main() { Test a(100),b(100); cout<<"a的內存地址:"<<&a<<" b的內存地址:"<<&b<<endl; Test c=a+b; cout<<"c的內存地址:"<<&c<<endl; cout<<c.a<<endl; system("pause"); }   運行過程見下圖。 [url=/bbs/detail_1785399.html][img]http://image.wangchao.net.cn/it/1323423594410.gif[/img][/url]   從圖中我們可以清楚的看到,不必要的運算過程被執行,導致開銷增大,讀者在理解此例的時候要格外小心! 現在總結一下轉換運算符的優點與缺點:   優點:在不提供帶有類對象參數的運算符重載函數的情況下,轉換運算符重載函數可以將類對象轉換成需要的類型,然後進行運算,最後在構造成類對象,這一點和類的運算符重載函數有相同的功效。(例2就是這種情況)   缺點:假如一個類只有轉換運算符重載函數,而沒有真正意義上運算符重載函數,當用轉換運算符重載函數替代運算符重載函數,進行工作的時候,就會讓程序的可讀性降低,歪曲了運算符操作的真正含義。(例2中的c=a+b;//隱式轉換,就是例子,事實上a+b的作用只是對返回的整型數據進行了加運算,而對象賦值的操作是系統隱式的幫大家轉換成了c=Test(a+b)。)   最後我們來說一下,多路徑轉換的多義性問題,多義性問題一直是C++編程中輕易忽視的問題,但它的確是不容小視,當問題隱藏起來的時候你不會發覺,一旦觸發麻煩就來了。   類的轉換構造函數與類的轉換運算符重載函數是互逆的。(例3中的Test(int a = 0)是將int類型的數據轉換構造成Test類對象,而operator int()則是將Test類對象轉換成int類型數據) 但是當他們是出現在兩個不同的類中,對于一個類對象轉換來說,同時擁有兩種近似的轉換途徑的時候,多義性的問題就暴露出來,導致編譯出錯。   下例就是這個狀態: //程序作者:管甯 //站點:www.cndev-lab.com //所有稿件均有版權,如要轉載,請務必聞名出處和作者 #include <iostream> using namespace std; class B; class A { public: A(B &);//轉換構造函數,他的作用是用B類對象構造A類對象 void Edita(int temp) { A::a=temp; } public: int a; }; class B { public: B(int a=0) { B::a=a; } int Ra() { return B::a; } operator A()//轉換運算符重載函數,他的作用則是將B類對象轉換成A類對象 { return *this; } PRotected: int a; }; A::A(B &temp) { cout<<this<<""<<&temp<<endl; A::a=temp.Ra(); } void tp(A temp) { } int main() { B BT(100); A at=A(bt); //tp(bt);//錯誤,多義性問題,系統不知道如何選擇,是選擇A(B &)轉化構造好呢?還是選擇B::operator A()進行轉換好呢? tp(A::A(bt));//顯示的處理可以消除多義性問題 system("pause"); }   代碼中的A at=A(bt);運行正常,因爲系統發現對象at還未構造,所以優先選取了A類的轉換構造函數處理了,沒有産生二義性問題。   但是代碼中的tp(bt);編譯錯誤,這是因爲函數tp的參數要求的是一個A類對象,而我們給他的則是一個B類對象,而在A類與B類中都有一個類似的操作,可以將B類對象轉換成A類對象,系統不知道是選取A類的轉換構造函數進行構造處理,還是選擇B類中的轉換運算符號重載函數處理,系統拒絕從他們兩個中選一個,所以編譯錯誤。   我們修改tp(bt)爲tp(A::A(bt));編譯正常,因爲我們顯式的明確的告訴系統應該使用A類的轉換構造函數處理,所以,顯式的告訴計算機應該如何處理數據,通常可以解決多義性問題。
󰈣󰈤
 
 
 
  免責聲明:本文僅代表作者個人觀點,與王朝網路無關。王朝網路登載此文出於傳遞更多信息之目的,並不意味著贊同其觀點或證實其描述,其原創性以及文中陳述文字和內容未經本站證實,對本文以及其中全部或者部分內容、文字的真實性、完整性、及時性本站不作任何保證或承諾,請讀者僅作參考,並請自行核實相關內容。
 
 
陽光靓麗的模特兒(8)
陽光靓麗的模特兒(7)
陽光靓麗的模特兒(6)
陽光靓麗的模特兒(5)
秋-印象
德慶盤龍峽 一
松江印象之三
雲之南(寬幅)
 
>>返回首頁<<
 
 
 
 熱帖排行
 
 
 
 
© 2005- 王朝網路 版權所有