7

这是(简化的)基类:

template <class T>
class SharedObject
{
protected:
    QExplicitlySharedDataPointer <typename T::Data> d;
};

这是派生的:

class ThisWontCompile : public SharedObject <ThisWontCompile>
{
private:
    friend class SharedObject;
    struct Data : public QSharedData
    {
        int id;
    };
};

是否有任何解决方法可以从SharedObject访问ThisWontCompile::Data?从基础对象派生的对象究竟能做什么,不能做什么?

4

1 回答 1

13

这实际上与可访问性和友谊无关,它与CRTP的使用有关。考虑以下也显示该问题的示例:

template <class T>
struct Base
{
    typedef typename T::Data Data;
};

struct ThisWontCompile : public Base<ThisWontCompile>
{
    struct Data { };
};

问题是ThisWontCompile它在用作 的模板参数时是不完整的Base,因此它只能用作 中的不完整类型Base

有关您的特定问题的一些解决方案,请查阅其他问题的答案,尤其是 Martin 建议使用特征类,基本上如下所示:

// Base
template <typename T>
struct BaseTraits;

template <typename T>
struct Base
{
    typedef typename BaseTraits<T>::Data Data;
};

// Derived
struct Derived;

template <>
struct BaseTraits<Derived>
{
    struct Data { };
};

struct Derived : public Base<Derived>
{
};

typename BaseTraits<Derived>::Data可以在Derived和 中使用Base。如果Derived它本身是一个模板,则可以对特征类使用部分特化。

于 2011-04-04T05:15:55.287 回答