在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
原文地址:https://www.jb51.cc/c/117803.html
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。