探究C++实现一个不可被担当的类[网络技术]
本文“探究C++实现一个不可被担当的类[网络技术]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:
根源:cnblogs
C#和Java都供应了一种机制让一个类不能被担当,如C#中的sealed关键字和Java的final关键字,但是C++程序员就没这么好命了.不过C++也可以模拟出这种效果,原理基于:子类的构造函数会自动调用父类的构造函数,同理析构函数也是一样.假如父类的构造函数和析构函数被设为私有的话,那么子类就无法调用,也就到达了父类不可被担当的目的了.原理很简单,按此原理我也实作出一个自认为很实用的工具类,在此献下丑,欢送大家批判:
template< typename TDerive, typename TProvider >
class CFobidDeriveProviderBase
{
friend TDerive;
friend TProvider;
private:
CFobidDeriveProviderBase(){}
~CFobidDeriveProviderBase(){}
};
/*
* 供应禁止派生的功效,需求此功效的类可以从CFobidDeriveProvider派生,并将类名作为模板参数传送
*/
template< typename TDerive >
class CFobidDeriveProvider : virtual public CFobidDeriveProviderBase< TDerive, CFobidDeriveProvider<TDerive>>
{
public:
CFobidDeriveProvider(){}
~CFobidDeriveProvider(){}
};
/*
* 测试类,该类不可被担当
*/
class CNoDerive : public CFobidDeriveProvider< CNoDerive >
{
public:
CNoDerive(){}
~CNoDerive(){}
void Alert()
{
AtlMessageBox( NULL, _T("Alert") );
}
};
之所以将担当的构造分为2层:CFobidDeriveProvider和CFobidDeriveProviderBase,主如果便利利用,用户只需直接从CFobidDeriveProvider派生便可实现一个不可被担当的类,而不需求虚拟担当.
若有类从CNoDerive派生:
class CSomeDerive : public CNoDerive
{
public:
CSomeDerive(){}
~CSomeDerive(){}
};
CSomeDerive的构造函数调用历程以下:由于CFobidDeriveProvider是从CFobidDeriveProviderBase虚拟派生,在虚担当呈现的担当层次中,老是在构造非虚基类之前构造虚基类,因而会跳过CNoDerive和CFobidDeriveProvider的构造函数而直接调用CFobidDeriveProviderBase的构造函数,但CSomeDerive不是CFobidDeriveProviderBase的友元,因此也无法调用CFobidDeriveProviderBase的私有构造函数.故而编译错误.
以上是“探究C++实现一个不可被担当的类[网络技术]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
本文地址: | 与您的QQ/BBS好友分享! |