对静态成员使用"template<>"
Use of "template<>" for static members
我遇到了一些让我感到困惑的代码。我已经将困惑提炼为一个简单的案例
template<typename T>
struct S
{
T member;
static const size_t size;
};
struct U { int i; };
typedef S<U> US_t;
template<> const size_t US_t::size = sizeof(U);
Q1:既然US_t
已经完全描述,为什么我需要在最后一行加上"template<>
"?
我实际遇到的代码 - 编译 - 相当于以下内容:
template<>template<> const size_t US_t::size = sizeof(U);
我很确定这是一个剪切和粘贴错误,因为它被编译了,所以没有被捕获。Q2: 这有效吗?如果是这样,为什么?[我注意到 codepad.org 将使用" template<>template<>
"编译代码。
将您的 typedef 想象为在编译时而不是预处理器时扩展的宏。
然后没有template<>
你会有
const size_t S<U>::size = sizeof(U);
这不是一个有效的语法,因为你正在做一个模板专用化。
相关文章:
- 如果C++类在类方法中具有动态分配,但没有构造函数/析构函数或任何非静态成员,那么它仍然是POD类型吗
- 如何在C++中使用非静态成员函数作为回调函数
- (C++)为什么静态成员可以在初始化之前使用
- 类的全局对象和静态成员
- 在作为静态成员包含在另一个类中的类的构造函数中使用 cout
- 模板化类中静态成员的延迟初始化
- 使用静态成员声明类时遇到问题
- C++:是否可以使用非静态成员变量模板?
- 静态成员函数使用相同的名称时出现模板类型名称错误
- 如何在复杂继承中访问静态成员变量
- 在 nullptr 上调用无状态类的非静态成员函数是否合法?
- 如何在友元函数中使用静态成员而不添加前缀 [类名]::
- C++构造函数和静态成员
- 为什么传递非静态成员函数会导致编译错误?
- 非静态成员失败的线程调用函数
- 静态成员变量不会由 gettext 转换
- decltype:使用指针访问类的静态成员
- 处理类内的回调时,必须调用对非静态成员函数的引用
- 非静态成员函数的 decltype 格式不正确吗?
- 如何在C++中定义静态成员结构