c++ 建構函式中explicit關鍵字的作用
阿新 • • 發佈:2019-02-13
C++ explicit關鍵字的作用主要是用來修飾類的建構函式,表明該建構函式是顯式的,禁止單引數建構函式的隱式轉換。
如果C++類的建構函式有一個引數,那麼在編譯的時候就會有一個預設的轉換操作:將該建構函式對應資料型別的資料轉換為該類物件,如下面所示:
class MyClass
{
public:
MyClass(int num);
}
MyClass my = 10;
上面的程式碼中編譯器自動將整型轉換為MyClass類物件,實際上等同於下面的操作:
MyClass temp(10);
MyClass obj = temp;
上面的所有的操作即是所謂的“隱式轉換”。
修改上面的MyClass類的建構函式為顯示的,下面的程式碼將不能夠編譯通過,如下所示:
class MyClass
{
編譯和執行截圖:
如果C++類的建構函式有一個引數,那麼在編譯的時候就會有一個預設的轉換操作:將該建構函式對應資料型別的資料轉換為該類物件,如下面所示:
class MyClass
{
public:
MyClass(int num);
}
MyClass my = 10;
上面的程式碼中編譯器自動將整型轉換為MyClass類物件,實際上等同於下面的操作:
MyClass temp(10);
MyClass obj = temp;
上面的所有的操作即是所謂的“隱式轉換”。
如果要避免這種自動轉換的功能,可以在宣告建構函式的時候前面新增上explict關鍵字,將類的建構函式宣告為“顯示”,這樣就可以防止這種自動的轉換操作。
class MyClass
{
public:
explicit MyClass(int num);
};
為了驗證這個功能,特做如下測試:
(--------------------1 建構函式前不加explicit---------------------)
#include <iostream> /********define********/ #ifndef MY_CLASS_H #define MY_CLASS_H class MyClass{ public: MyClass(int); }; #endif /********class*********/ MyClass::MyClass(int i) { std::cout<<"i="<<i<<std::endl; } /********main**********/ int main(int argc,char **argv) { MyClass my=10; return 0; }
編譯和執行截圖:
(------------------------2 建構函式前加explicit-------------------)
#include <iostream> /********define********/ #ifndef MY_CLASS_H #define MY_CLASS_H class MyClass{ public: explicit MyClass(int); }; #endif /********class*********/ MyClass::MyClass(int i) { std::cout<<"i="<<i<<std::endl; } /********main**********/ int main(int argc,char **argv) { MyClass my=10; return 0; }
編譯報錯,如圖所示:
可知,c++建構函式前的explicit正是上面所說的功能。