7

在 VC++10 中,以下示例失败并出现错误 C2027:“使用未定义类型 'X'”。但是 g++ 4.6 编译它就好了。

template<class T>
class C
{
    static const size_t size = sizeof(T);
};

class X : public C<X> { };

那么哪一个是对的呢?我将如何做到这一点,以便它适用于主流编译器?

不过这并不是什么大问题,因为 VC++ 仍然允许在 C 的成员函数中使用 sizeof(T)。我只需要重复一些很烦人的长类型定义。

编辑: 我意识到我的例子很糟糕,因为我真正想做的是使用大小作为编译时间常数,以这种方式:

template<size_t size> class C2 { };

template<class T>
class C
{
   typedef C2<sizeof(T)> A;
};

class X : public C<X> { };

两个编译器都拒绝这个,所以我认为这可能是不可能的,但就像我说的,我仍然可以在函数内部使用 sizeof。我只是希望我不必在每个函数中重复 typedef。

template<size_t size> class C2 { };

template<class T>
class C
{
    void foo() { typedef C2<sizeof(T)> A; }
};

class X : public C<X> { };
4

1 回答 1

6

静态成员不能在类本身初始化,因为类型T正在定义中,尚未完成。

但是,您可以在类外部将其初始化为:

template<class T>
class C
{
    static const size_t size;
};

template<typename T>
const size_t C<T>::size = sizeof(T); //initialization of the static member

它应该编译得很好:http: //ideone.com/6sNgN

于 2011-12-17T12:26:34.173 回答