如何专门化非模板类的模板化构造函数?下面的代码用gcc和icc编译好,但不能用clang和msvc编译。
代码a)是非法的,但icc / gcc无论如何编译它或b)是合法的但是clang / msvc由于某种原因无法编译。
复制者:
$ cat template_01.cpp
struct A
{
template<class T>
A(T const &t);
};
template<>
A::A<double>(double const& t) {}
int main()
{
A a(42.0);
}
重现步骤:
$ clang++ template_01.cpp
template_01.cpp:8:4: error: qualified reference to 'A' is a constructor name rather than a type wherever a constructor can be declared
A::A<double>(double const& t) {}
^
template_01.cpp:8:5: error: expected unqualified-id
A::A<double>(double const& t) {}
^
2 errors generated.
$
$ g++ template_01.cpp
$
$ icc template_01.cpp
$
$ cl.exe template_01.cpp
Microsoft (R) C/C++ Optimizing Compiler Version 18.00.40629 for x86
Copyright (C) Microsoft Corporation. All rights reserved.
template_01.cpp
template_01.cpp(8) : error C2143: syntax error : missing ';' before '<'
template_01.cpp(8) : error C2988: unrecognizable template declaration/definition
template_01.cpp(8) : error C2059: syntax error : '<'
template_01.cpp(11) : error C2143: syntax error : missing ';' before '{'
template_01.cpp(11) : error C2447: '{' : missing function header (old-style formal list?)
$
答案 0 :(得分:3)
我相信,这是CLang的一个错误。标准中没有任何内容阻止构造函数的显式特化,并且gcc中的类似问题被认为是一个错误:
答案 1 :(得分:0)
我通过搜索找到了这里,链接 T.C.提到的说了算(2019年)。
现在确定在构造函数模板特化中“不应指定模板参数”。 IE。以下代码有效:
template<>
A::A(double const& t) {}
并且我已经确认 GCC 和 Clang 现在都接受它。