当前位置:七道奇文章资讯安全技术网络技术
日期:2009-07-05 16:39:00  来源:本站整理

探究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++实现一个不可被担当的类[网络技术]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • <b>探究C++实现一个不可被担当的类</b>
  • 探究C++实现一个不可被担当的类
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .