C++ 中不能被继承的类实现,及从中体现virtual 继承的一个特性
C++ view第一期中給出了如何實(shí)現(xiàn)一個(gè)不能被繼承的類的方法。
如下:
#ifdef NDEBUG
#define FINAL_CLASS
#else
#define FINAL_CLASS : public virtual Private::NonDerivableHelper? //這里的關(guān)鍵是virtual 只要是virtual就不能繼承
#endif
namespace Private
{
class NonDerivableHelper
{
??? protected:
??????? NonDerivableHelper(int) { cout << "a" << endl;} //ADDED CTOR ARGUMENT
};
}
class NonDerivable FINAL_CLASS
{
??? public:
??????? NonDerivable() : NonDerivableHelper(0) {cout << "b" << endl;} //PASS A DUMMY VALUE
};
class A: public NonDerivable
{
??? public:
??????? A() { cout << "c" << endl;}
};
int main(int argc, char *argv[])
{
??? NonDerivable n;
??? A a;
??? return 0;
}
?
?這里A試圖繼承 NonDerivable 類,但是編譯器會(huì)報(bào)錯(cuò)
underivable.cc|55| 錯(cuò)誤: 對(duì)‘Private::NonDerivableHelper::NonDerivableHelper()’的調(diào)用沒有匹配的函數(shù)
underivable.cc|40| 附注: 備選為: Private::NonDerivableHelper::NonDerivableHelper(int)
underivable.cc|38| 附注:????????? Private::NonDerivableHelper::NonDerivableHelper(const Private::NonDerivableHelper&)
這也就是選擇virtual 繼承的原因,選擇virtual繼承,構(gòu)造函數(shù)時(shí)會(huì)跳過NonDerivable() : NonDerivableHelper(0) 而直接去調(diào)用
NonDerivableHelper(int)
在虛繼承出現(xiàn)的繼承層次中,總是在構(gòu)造非虛基類之前構(gòu)造虛基類。參考http://tech.ddvip.com/2009-07/1246614951125275.html。
即使是非virtual繼承也是基類先被構(gòu)造,但是構(gòu)造函數(shù)的選擇是要由子類決定的,如果子類不提供信息則才調(diào)用基類的默認(rèn)構(gòu)造函數(shù)。
而在這里的virtual繼承使得首先就越過NonDerivable,直接去構(gòu)造NonDerivableHelper。
?
做個(gè)小實(shí)驗(yàn)就清楚了
?
#ifdef NDEBUG
#define FINAL_CLASS
#else
#define FINAL_CLASS : public virtual Private::NonDerivableHelper? //這里的關(guān)鍵是virtual 只要是virtual就不能繼承
#endif
namespace Private
{
class NonDerivableHelper
{
??? protected:
??????? NonDerivableHelper(int) { cout << "a" << endl;} //ADDED CTOR ARGUMENT
??????? NonDerivableHelper() { cout << "a!" << endl;}
};
}
class NonDerivable FINAL_CLASS
{
??? public:
??????? NonDerivable() : NonDerivableHelper(0) {cout << "b" << endl;} //PASS A DUMMY VALUE
};
class A: public NonDerivable
{
??? public:
??????? A() { cout << "c" << endl;}
};
int main(int argc, char *argv[])
{
??? //A a;
??? NonDerivable n;
??? A a;
??? return 0;
}
?
運(yùn)行結(jié)果
a
b
a!
b
c
將virtual 去掉
即 #define FINAL_CLASS : public Private::NonDerivableHelper? //這里的關(guān)鍵是virtual 只要是virtual就不能繼承
運(yùn)行結(jié)果
a
b
a
b
c
OK, virtual? 繼承和非virtual繼承在構(gòu)造函數(shù)調(diào)用上的不同已經(jīng)很清楚了,a與a!的區(qū)別。
?
與50位技術(shù)專家面對(duì)面20年技術(shù)見證,附贈(zèng)技術(shù)全景圖總結(jié)
以上是生活随笔為你收集整理的C++ 中不能被继承的类实现,及从中体现virtual 继承的一个特性的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: WCF技术剖析之十一:异步操作在WCF中
- 下一篇: 如何修改VC6的项目名