1

我有这3节课。

class A  
{  
    public:  
        virtual void Func() = 0;  
};

template<class T>  
class B : public A  
{  
    public:  
        void Func()  
        {  
            cout << "In B" << endl;  
            static_cast<T*>(this)->Func();  
        }  
};  

class C : public B<C>  
{  
    public:  
        void Func()  
        {  
            cout << "In C" << endl;  
        }  
};  

而且,我这样做:

int main(int argc, char **argv)  
{  
    A *a = new C;  
    a->Func();  

    return 0;  
}  

它打印:“在 C 中”。

如果我这样做,

int main(int argc, char **argv)  
{  
    B<C> *a = new C;  
    a->Func();  

    return 0;  
}  

它再次打印“In C”

到底是怎么回事?

4

3 回答 3

1

您正在调用重载此函数的类 C 对象的虚拟成员函数。它调用 C 类中的函数。

此外,这不是 CRTP,因为模板类 B 不继承自类模板参数。

于 2010-02-24T10:44:49.243 回答
1

Func是虚拟的,a是指向 的实例的指针C,因此调用C的版本。Func

于 2010-02-24T10:51:50.810 回答
0

代码不完整,添加#include和“using namespace std;”。更重要的是,你可以通过去掉 A 中的虚函数声明来获得想要的行为。一般来说,使用 CRTP 的主要原因是让模板知道它接收到的类型并避免进行虚调用(或者更好的是,避免制作方法虚拟的)。

template <typename T>
class ClassUsingSomething {
  public:
    void method1() {
      // I need to call method2, I do this by casting, so it doesn't need to be virtual.
      static_cast<T *>(this)->method2();
    }
};

class A: public ClassUsingSomething<A> {
  public:
    void method2() {
      //do something
    }
};
于 2010-05-05T16:58:06.580 回答