第一章policy(特征,模板中的模板类)

1、如果需要写出一个smartptr供外部使用

template<typename T>

class CSmartPtr

外部可能需要支持单线程,或则多线程的(CThread,CSingleThread)。需要支持check指针为空或则设置默认值的(CNocheck,CEnfoceNotNull,CEnsureNotNull)

按照面向对象或则设计模式的解法为:线程是一个class,CSmartPtr继承自,也从CCheck继承自,这样会有很多种组合需要写

模板带来的曙光

template<typename T>

class CNoCheck()

{

static void Check(T*){} // Nocheck,什么也不做

}

template<typename T> 
class CEnforceNotNull
{
public:
static void Check(T* ptr)
{
if (!ptr)
{
throw std::exception();
}
}
};

template<typename T>
class EnsureNotNull
{
public:
static void Check(T*& ptr)
{
if (!ptr)
{
ptr = GetDefaultT();
}
}


static T* GetDefaultT()
{
static T* staticT = NULL;
if (!staticT)
{
staticT = new T;
}
return staticT;
}
};


// CSmartPtr可以根据不同的基类产生不同的类
// 如果不使用模板,我们就需要
template<typename T, 
template<typename> class Checkpolicy = EnsureNotNull>
class CSmartPtr: public Checkpolicy<T>
{
public:
CSmartPtr(T* pT)
: m_pT(pT)
{


}
~CSmartPtr(void)
{


}


T* operator ->()
{
Checkpolicy<T>::Check(m_pT);
return m_pT;
}
private:
T* m_pT;
};

如果需要使用,我们只需要

CSmartPtr<MyType, CNoCheck>  aa;即可

CSmartPtr第二个参数就是一个模板,CNoCheck也刚好就是一个模板,CSmartPtr继承自CNocheck<MyType>。

而且我们不能写CSmartPtr<MyType, CNoCheck<MyType> >,这样会不符合参数,第二个类编程了一个具体类了,实际上它就是需要一个模板类。

是不是很神奇?模板中的模板类,在需要继承自多个类时,试试让外部控制继承对象。这样可以轻易的创造出很多不同的组合

而且上面还有个函数GetDefaultT也是一种方法,可以给某个类特例一个函数接口

根据继承的类进行判断,如果继承自其它的调用会编译错误,也可用来做检测是否继承自EnsureNotNull




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值