c – 使用CRTP时如何获取模板参数的大小?

在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> { };

解决方法

静态成员无法在类本身中初始化,因为正在定义类型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

相关文章

本程序的编译和运行环境如下(如果有运行方面的问题欢迎在评...
水了一学期的院选修,万万没想到期末考试还有比较硬核的编程...
补充一下,先前文章末尾给出的下载链接的完整代码含有部分C&...
思路如标题所说采用模N取余法,难点是这个除法过程如何实现。...
本篇博客有更新!!!更新后效果图如下: 文章末尾的完整代码...
刚开始学习模块化程序设计时,估计大家都被形参和实参搞迷糊...