下面的代码用g编译,但无法用clang编译 .
struct X;
template <typename T>
struct Traits
{
typedef typename Traits<T>::Container Container;
};
template <>
struct Traits<X>
{
typedef std::vector<X *> Container;
};
int main()
{
Traits<X>::Container container;
return EXIT_SUCCESS;
}
clang错误信息:
main.cpp:9:30: error: no type named 'Container' in 'Traits<T>'
编译器是否应该评估typedef而不用实际类型替换template参数?哪个编译器是对的?
1 回答
这是形成不良,无需诊断 . 没有
T
这样上述(主要)专业化可能导致有效的代码 .另一种专业化的存在没有任何区别 . 编译器可以自由地执行任何操作,包括提供虚假错误消息 . 编译它是免费的 . 只有在程序中有一个名为
foo
的变量或月亮是新的时,才可以自由生成错误 . 如果这些是执行质量差的一些 .在实践中,这意味着编译器可以自由地假设主要特化对某些类型
T
有效(即,在其中没有无限递归),并且在相对不相关的代码中废弃,因为它做出了这个假设 .