【c++】【转】c++中的explicit关键字
http://www.cnblogs.com/chio/archive/2007/09/17/895263.html
c++中的explicit關鍵字用來修飾類的構造函數,表明該構造函數是顯式(調用)的,既然有"顯式"那么必然就有"隱式",那么什么是顯示而什么又是隱式的呢?
如果c++類的構造函數有一個參數,那么在編譯的時候就會有一個缺省的轉換操作:將該構造函數參數對應數據類型的數據轉換為該類對象,如下面所示:
class MyClass { public:MyClass(int num){}; };MyClass obj = 10;//10被隱式調用構造函數轉換為MyClass類型對象在上面的代碼中編譯器自動將整型轉換為MyClass類對象,實際上等同于下面的操作:
MyClass temp(10);
MyClass obj = temp;
上面的所有的操作即是所謂的"隱式轉換"。
如果要避免這種自動轉換的功能,我們該怎么做呢?這就是關鍵字explicit的作用了,將類的構造函數聲明為"顯式",也就是在聲明構造函數的時候前面添加上explicit即可,這樣就可以防止這種自動的轉換操作,如果我們修改上面的MyClass類的構造函數為顯式的,那么下面的代碼就不能夠編譯通過了,如下所示:
class MyClass { public:explicit MyClass(int num){}; };MyClass obj = 10;//出錯?
?
class Rational { public:Rational(int numerator = 0, int denominator = 1){this->numerator = numerator;this->denominator = denominator;}~Rational(){}int get_numerator(){return numerator;}int get_denominator(){return denominator;}const Rational operator*(const Rational &rhs) const;private:int numerator;int denominator; };const Rational Rational::operator*(const Rational &rhs) const {return Rational(numerator * rhs.numerator, denominator*rhs.denominator); }int main() {Rational a(2, 1);//Rational b = 2 * a;//編譯出錯,相當于2.operator*(a),而2不是Rational類型Rational b = a * 2;//2會被隱式類型轉換為Rational對象cout << b.get_numerator() << " " << b.get_denominator() << endl;system("pause");return 0; }上述有理數運算不滿足交換律,所以需要改進
class Rational { public:Rational(int numerator = 0, int denominator = 1){this->numerator = numerator;this->denominator = denominator;}~Rational(){}int get_numerator() const{return numerator;}int get_denominator() const{return denominator;}private:int numerator;int denominator; };const Rational operator*(const Rational& lhs,const Rational &rhs) {return Rational(lhs.get_numerator() * rhs.get_numerator(), lhs.get_denominator()*rhs.get_denominator()); }int main() {Rational a(2, 1);//2會被隱式類型轉換為Rational對象Rational b = 2 * a;//Rational b = a * 2;cout << b.get_numerator() << " " << b.get_denominator() << endl;system("pause");return 0; }總結:如果你需要為某個函數的所有參數進行類型轉換,那么這個函數必須是個non-member(effective c++ 條款24)
絕不要返回指針或引用指向一個local stack對象,因為local stack對象當退出函數時就被析構了,也就是說指針或者引用指向未知的內存;不要返回引用指向一個heap-allocated對象,會導致內存泄漏;不要返回指針或引用指向一個local static對象,因為有可能同時需要多個這樣的對象,此時這些對象其實都是同一個對象。所以一個必須返回新對象的函數的正確寫法是:讓那個函數返回一個新對象,不用擔心拷貝構造函數導致的性能損失。例子可見上面的operator*的寫法(effective c++ 條款21)
轉載于:https://www.cnblogs.com/ljygoodgoodstudydaydayup/p/3897349.html
總結
以上是生活随笔為你收集整理的【c++】【转】c++中的explicit关键字的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 设计根据标示符全局只运行一次的类
- 下一篇: C++中函数模板template和函数参