Item 43: 学习处理模板化基类内的名称

模板都会编译两次,第一次检查语法,第二次具现化。假如模板有不同参数,则会对每个参数都具现一次。如果参数不确定,则不可能具现,也就不知道它的行为。 
一个类模板继承于另一个相同模板参数的基类,派生类使用到基类的成员时,编译器往往会报错该成员未定义。因为在第一次编译的语法检查中,即使知道Derived继承自Base,但其中的T是个template参数,不到Derived被具现化无法确切知道它是什么,而如果不知道T是什么,就无法知道Base看起来像什么——于是就不知道它是否有什么成员(因为Base是可以被全特化,那么编译器无法知道这个全特化后的Base是否包含member function)。有三种方法可以令C++“不进入templatized base class观察”的行为失效: 
(1)当需要用到base class的成员时,在该成员前加上this-> 
(2)使用using声明告诉编译器,使它进入base class作用域内查找 
(3)明白指出被调用的函数位于base class内。即Base::member 
第三种解法往往是最不让人满意的一种。因为如果被调用的是virtual函数,使用明确指出的方式会关闭virtual绑定行为。 
除此之外,这三种解法做的事情都相同:对编译器承诺base class template的任何特化版本都支持其一般版本所提供的接口 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值