QT中的explicit關鍵字的作用


c++提供了關鍵字explicit,可以阻止不應該允許的經過轉換構造函數進行的隱式轉換的發生。聲明為explicit的構造函數不能在隱式轉換中使用。

  C++中, 一個參數的構造函數(或者除了第一個參數外其余參數都有默認值的多參構造函數), 承擔了兩個角色。一是個構造器,二是個默認且隱含的類型轉換操作符。

  所以,有時候在我們寫下如 AAA = XXX, 這樣的代碼, 且恰好XXX的類型正好是AAA單參數構造器的參數類型, 這時候編譯器就自動調用這個構造器, 創建一個AAA的對象。

這樣看起來好象很酷,很方便。 但在某些情況下,卻違背了我們(程序員)的本意。 這時候就要在這個構造器前面加上explicit修飾, 指定這個構造器只能被明確的調用、使用,不能作為類型轉換操作符被隱含的使用。  

  請看下面的代碼:

  1 class Test1

  2 {

  3 public:

  4 Test1(int n) { num = n; } //普通構造函數

  5 private:

  6 int num;

  7 };

  8

  9 class Test2

  10 {

  11 public:

  12 explicit Test2(int n) { num = n; } //explicit(顯式)構造函數

  13 private:

  14 int num;

  15 };

  16

  17 int main()

  18 {

  19 Test1 t1 = 12; //隱式調用其構造函數成功

  20 Test2 t2 = 12; //編譯錯誤,不能隱式調用其構造函數

  21 Test2 t3(12); //顯示調用成功

  22 return 0;

  23 }

  Test1的構造函數帶一個int型的參數,代碼19行會隱式轉換成調用Test1的這個構造函數。而Test2的構造函數被聲明為explicit(顯式),這表示不能通過隱式轉換來調用這個構造函數,因此代碼20行會出現編譯錯誤。普通構造函數能夠被隱式調用。而explicit構造函數只能被顯示調用。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM