【发布时间】:2011-08-03 16:42:54
【问题描述】:
我正在阅读 Vandevoorde 和 Josuttis 的“C++ 模板完整指南”(顺便说一句,这似乎很不错)。这种说法(第 3.3 节)似乎是错误的and is not in the published errata:
如果您特化一个类模板,您还必须特化所有成员函数。虽然可以特化单个成员函数,但是一旦你这样做了,你就不能再特化整个类。
以下是在 gcc 上编译的 模板
<typename T>
struct C {
T foo ();
T bar ();
};
template <>
struct C<int> {
int foo ();
int bar () {return 4;}
};
template <typename T>
T C<T> :: foo () {return 0;}
template <typename T>
T C<T> :: bar () {return 1;}
int C<int> :: foo () {return 2;}
template <>
float C<float> :: bar () {return 3;}
#include <cassert>
int main () {
C<int> i;
C<float> f;
assert (2 == i .foo ());
assert (0 == f .foo ());
assert (4 == i .bar ());
assert (3 == f .bar ());
}
我有专门的C<int>::foo和C<float>::bar所以是教科书错了,是gcc超出了标准,还是我误解了整个情况?
谢谢。
【问题讨论】:
-
您误解了规则。一旦你特化了一个成员函数,你就不能在同一类型上特化一个类,而不是在所有其他类型上。
标签: c++ templates gcc template-specialization