dev下模板化基类的问题

来源:互联网 发布:数据库概念模型图 编辑:程序博客网 时间:2024/06/07 03:29
#include<iostream>
template<class T>
class base
{
public:
    base():n(10){}
    void func1(){std::cout<<n;}
protected:
    T n;
};
template<class T>
class derived:public base<T>
{
public:
    //dev下,这里会无法通过编译,原因是func1的调用取决于模板参数  ,
    //这实际上是由于模板特化机制引起的
    void func2(){func1();}
};
int main()
{
    derived<int> obj;
    obj.func2();
    return 0;   
}

  base这个基类是个类模板,派生类derived继承它,并在func2中调用基类的func1,这段代码在vc下没有问题,但是在dev下不能通过编译,原因是编译器无法提前得知:base这个类模板有没有定义它的特化版本?(这一切都得在实例化的时候才能知道)这个func1可能并不会出现在base的某个特化版本中,所以编译器不会在基类base中寻找名称。
  解决办法:
1.在给dev编译器一个“-fpermissive”参数,通知其做出假设:func1的定义肯定存在!于是对错误的检查就留给了连接器。
2.显式的声明func1的位置:
template<class T>
class derived:public base<T>
{
public:
    using base<T>::func1;
    //如果你同时也想用n,那么就加上using base<T>::n;
    void func2(){func1();}
    //或者void func2(){base<T>::func1();}           
};
3.在func1前面加上“this->”,void func2(){this->func1();}

ps:这个问题我首先在《数据结构-使用c++语言描述》一书中遇到,始终不明白为什么模板基类的n不能在派生类中用!那时我写代码一般用dev,而别的同学都用vc6,vc对这个问题的处理和dev不同,后来恍然大悟。。。

  参考:《effective c++ third edition》,条款43:正确处理模板化基类内的名称。
原创粉丝点击