【C++基金会 06】explictkeyword
生活随笔
收集整理的這篇文章主要介紹了
【C++基金会 06】explictkeyword
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
C++提供keywordexplicit,你應該不能阻止的轉換構造隱式轉換發生的同意。聲明explicit的構造不能在一個隱式轉換使用。
1.演示樣例
我們先來看一段演示樣例代碼:
class A { public:A(int v):var(v){};//帶一個int型值的構造函數bool isSame(const A& ref) const {return var == ref.var;}//判等函數 private:int var;//成員變量var };void main() {A a(5);//構造a對象A b(5);//構造b對象if (a.isSame(b))cout<<"a==b"<<endl;elsecout<<"a!=b"<<endl; }上述代碼獲得結果是a==b。假設A b(3),獲得的結果就是a!=b。
2.構造函數定義引起的隱式轉換
因為構造函數須要傳入一個int型初始值,因此能夠覺得這是一個隱式轉換。把一個int型值轉換為一個A類型的對象。
所以假設改動main函數為例如以下代碼。
3.抑制抑制由構造函數定義的隱式轉換
在構造函數中引入explicit能夠幫我們解決問題。class A { public:explicit A(int v):var(v){};//帶一個int型值的構造函數bool isSame(const A& ref) const {return var==ref.var;}//判等函數 private:int var;//成員變量var };void main() {A a(5);//構造a對象if (a.isSame(5))cout<<"a==b"<<endl;elsecout<<"a!=b"<<endl; }//輸出結果 error C2664: “A::isSame”: 不能將參數 1 從“int”轉換為“const A &” 1> 原因例如以下: 無法從“int”轉換為“const A” 1> 這樣一來構造函數就無法進行隱式轉換,
4.為轉換進行顯式使用構造函數
這時候仍想進行轉換的話。顯式使用構造函數吧。class A { public:explicit A(int v):var(v){};//帶一個int型值的構造函數bool isSame(const A& ref) const {return var==ref.var;}//判等函數 private:int var;//成員變量var };void main() {A a(5);//構造a對象if (a.isSame(A(5))//顯示使用構造函數cout<<"a==b"<<endl;elsecout<<"a!=b"<<endl; }
5.總結
除非有明顯的理由想利用構造函數定義的隱式轉換。否則設置explicit能夠避免一些錯誤,當須要進行轉換的時候,由用戶顯式地調用構造函數。當然C++的暫時對象都是const,假設isSame函參不是const型。則隱式調用構造函數時生成的瞬態對象不能傳遞。版權聲明:本文博主原創文章,博客,未經同意不得轉載。
總結
以上是生活随笔為你收集整理的【C++基金会 06】explictkeyword的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: SpringMVC 通过post接收fo
- 下一篇: oc字符串的用法