C 中隱式類型轉換是指:從「建構函數形參類型」到「該類別類型」的一個編譯器的自動轉換。隱式類別類型轉換是會帶來風險的,隱式轉換得到類別的臨時變量,完成操作後就消失了,我們建構了一個完成測試後被丟棄的物件。
C 隱含類別類型轉換
《C Primer》中提到:
「可以用單一形參來呼叫的建構子定義了從形參類型到該類別類型的一個隱式轉換。」
#這裡要注意的是, 「可以用單一形參進行呼叫」 並不是指建構子只能有一個形參,而是它可以有多個形參,但那些形參都是有預設實參的。
那麼,什麼是「隱式轉換」呢?上面這句話也說了,是從 建構函數形參類型 到 該類別類型 的一個編譯器的自動轉換。
下面透過程式碼來看一看:
#include "stdafx.h" #include <string> #include <iostream> using namespace std ; class BOOK //定义了一个书类 { private: string _bookISBN ; //书的ISBN号 float _price ; //书的价格 public: //定义了一个成员函数,这个函数即是那个“期待一个实参为类类型的函数” //这个函数用于比较两本书的ISBN号是否相同 bool isSameISBN(const BOOK & other ){ return other._bookISBN==_bookISBN; } //类的构造函数,即那个“能够用一个参数进行调用的构造函数”(虽然它有两个形参,但其中一个有默认实参,只用一个参数也能进行调用) BOOK(string ISBN,float price=0.0f):_bookISBN(ISBN),_price(price){} }; int main() { BOOK A("A-A-A"); BOOK B("B-B-B"); cout<<A.isSameISBN(B)<<endl; //正经地进行比较,无需发生转换 cout<<A.isSameISBN(string("A-A-A"))<<endl; //此处即发生一个隐式转换:string类型-->BOOK类型,借助BOOK的构造函数进行转换,以满足isSameISBN函数的参数期待。 cout<<A.isSameISBN(BOOK("A-A-A"))<<endl; //显式创建临时对象,也即是编译器干的事情。 system("pause"); }
程式碼中可以看到,isSameISBN函數是期待一個BOOK類別類型形參的,但我們卻傳遞了一個string類型的給它,這不是它想要的!還好,BOOK類別中有個建構函數,它使用一個string類型實參進行調用,編譯器調用了這個建構函數,隱式地將stirng類型轉換為BOOK類型(建構了一個BOOK臨時物件),再傳遞給isSameISBN函數。
隱式類別類型轉換還是會帶來風險的,正如上面標記,隱式轉換得到類別的臨時變量,完成操作後就消失了,我們建構了一個完成測試後被丟棄的物件。
我們可以透過explicit宣告來抑制這種轉換:
explicit BOOK(string ISBN,float price=0.0f):_bookISBN(ISBN),_price(price){}
explicit關鍵字只能用於類別內部的建構子宣告上。這樣一來,BOOK類別建構子就不能用於隱式地創造物件了,編譯上面的程式碼會出現這樣的提示:
現在使用者只能進行顯示類型轉換,明確地建立臨時物件。
總結一下:
可以使用一個實參來調用,不是指建構函式只能有一個形參。
隱式類別類型轉換容易引起錯誤,除非你有明確理由使用隱式類別類型轉換,否則,將可以用一個實參進行呼叫的建構子都宣告為explicit 。
explicit只能用於類別內部建構子的宣告。它雖然能避免隱式類型轉換帶來的問題,但需要使用者能夠明確地建立臨時物件(對使用者提出了要求)。
推薦:《C 教學》
以上是C++隱式型別轉換是什麼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!