请考虑我的代码的以下简化版本。 我有一个模板类A
,模板功能Fill
,并与基本类型,如int
或char
工作功能的专业化,另一个专业化与A
工作:如何让编译器使用正确的模板专业化?
#include <sstream>
#include <string>
#include <iostream>
template<size_t C>
class A
{
public:
A & operator=(std::string v) {
data[0] ='a';
return *this;
}
char data[C];
};
template<typename T> T Fill(std::string value, T default_value);
// Specialization for A<C>
template<size_t C>
A<C> Fill(std::string value, A<C> default_value)
{
if (value.empty())
return default_value;
A<C> result;
result = value;
return result;
}
// Specialization for int, double, char, etc
template<typename T>
T Fill(std::string value, T default_value)
{
if (value.empty())
return default_value;
T result;
std::istringstream(value) >> result;
return result;
}
void main()
{
int abc = Fill(/*Get a string somehow*/"123", 0); // OK
A<10> def;
def = std::string("111");
A<10> a;
a = Fill(/*Get a string somehow*/"abc", def); // OK
}
,虽然我工作正常m惊讶于编译器设法将参数匹配到正确的模板特化。
这个问题伴随着一些typedef
s,易于使用A<x>
。这里是一个简化的版本:
typedef A<12> A12;
...
A<12> def12;
def12 = std::string("12");
A12 a12;
a12 = Fill(/*Get a string somehow*/"xyz", def12); // Not OK !
编译器不检测的类型A12
实际上是A<12>
和使用功能,不编译,因为istringstream不能与邻perator>>
解析为一个A
错误的专业化。
我该如何使用正确的模板专业化?
在第二个例子中如何声明** def **? – 2011-05-19 15:40:54
功能模板不能部分专用(而且你还没有使用专门化语法),所以在你的例子中你实际上是超载。 – 2011-05-19 17:45:36