模板类中的静态变量,用于继承时子类的静态变量的独占

My文章总结:

用于继承时,模板函数基类,子类可以拥有属于子类本身自己的静态变量,而不是所有的子类共用父类的静态变量。如果使用非模板函数基类,所有的子类共用父类的的静态变量。


http://hi.baidu.com/rwen2012/item/6dad109ee0d7bac9b6253149


C++: 静态成员和子继承

Meyers在条款7中给出了一个用于实现 "class   专属的new-handlers ",用class   X实现了一个 
用template和inheritance实现了一个,在template版本中,Meyers解释说: 
之所以使用inheritance是为了使derived   class   也具有这种能力(class   专属的new-handlers)。 
而之所以使用template,是因为确保每一份derived   class拥有一个不同的currentHandler   data   
member,(侯捷解释:因为它(变量   currentHandler)是一个static   data   member,所以才需要 
这项特别技术),请教侯捷为什么做出这样的解释? 
位置:effective   c++   第二版,p31,右下一段!

==========================

基类的静态成员是唯一的,如果不用模板,所有从NewHandlerSupport继承的类的currentHandler都一样,你在一个派生类里set_new_handler之后,其他派生类的currentHandler就不能用了。 

而以派生类类型为参数的模板基类,每个派生类的基类其实都不一样,其静态成员就是每个派生类自已有一个了。 

比如说 
class   B{public   static   int   a;}; 
int   B::a; 
class   D1   :   public   B{}; 
class   D2   :   public   B{}; 
... 
D1   x;   D2   y; 
x.a   =   1; 
assert(y.a   ==   1); 
如上,D1和D2的a是相同的。而 
template <typename   T>   class   B{public   static   int   a;}; 
template <typename   T>   int   B <T> ::a; 
class   D1   :   public   B <D1> {}; 
class   D2   :   public   B <D2> {}; 
... 
D1   x;   D2   y; 
x.a   =   1; 
y.a   =   2; 
assert(x.a   ==   1); 
assert(y.a   ==   2); 
D1和D2有不同的a。 

http://topic.csdn.net/t/20041030/22/3506899.html


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值