我对类模板的 ctor 重载解析有一个简单的问题:
#include <iostream>
#include <string>
using namespace std;
enum EnumTypeVal { READ, WRITE };
template <class T>
class TemplateClassTest {
public:
TemplateClassTest(const string & stringVal, T typeVal, EnumTypeVal e = READ,
const string & defaultStringVal = "default");
TemplateClassTest(const string & stringVal, const char * charVal);
TemplateClassTest(const string & stringVal, EnumTypeVal e = READ,
const string & defaultStringVal = "default");
private:
T type;
};
template <class T>
TemplateClassTest<T>::TemplateClassTest(const string & stringVal, T typeVal,
EnumTypeVal e,
const string & defaultStringVal)
{
type = typeVal;
cout << "In TemplateClassTest(const string &, T, EnumTypeVal, "
"const string &)" << endl;
}
template <class T>
TemplateClassTest<T>::TemplateClassTest(const string & stringVal,
const char * charVal)
{
cout << "In TemplateClassTest(const string &, const char *)" << endl;
}
template <class T>
TemplateClassTest<T>::TemplateClassTest(const string & stringVal, EnumTypeVal e,
const string & defaultStringVal)
{
cout << "In TemplateClassTest(const string &, EnumTypeVal, const string &)"
<< endl;
}
typedef TemplateClassTest<long long unsigned int> u32Type;
typedef TemplateClassTest<bool> boolType;
int main()
{
u32Type l("test", "0"); //matches ctor 2
u32Type v("test", 0); // ambiguity between ctor 1 and 2
boolType b("test", "true"); //matches ctor 2
return 0;
}
第二次调用编译失败,抛出错误:
重载 'TemplateClassTest(const char [5], int) 的调用不明确。
为什么int
匹配到const char *
?这种情况可以通过将 ctor 2 中的 to 更改来解决const char *
。const string &
但是这样做,boolType b("test", "true")
现在匹配到 ctor 1 而不是 ctor 2。
我的要求是:
u32Type v("test", 0)
应该匹配 ctor 1boolType b("test", "true")
应该匹配 ctor 2。
限制是:
- ctor 1 和 3 签名无法更改
- main() 中的用户代码调用无法更改。
任何帮助都非常感谢..谢谢!