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 – 使用CRTP时如何获取模板参数的大小?全部内容,希望文章能够帮你解决c – 使用CRTP时如何获取模板参数的大小?所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)