c++模板与STL返回类型的组合
C++ template combined with STL return types
我有一个模板化的类
template <typename T>
class Factors
{
public:
Factors(){};
deque<string> stringsDeck;
// some methods and variables here
map <string, string> getNext();
};
getNext
方法将作为键的字符串与作为值的stringsDeck
中的字符串组合,并返回一个map <string,string>
。假设我已经模板化了stringify
和string2num
函数,我想要有一个方法map<string,Scalar> getNext()
,它用于除字符串以外的所有其他类型,将映射的值转换为指定的模板类型T
。
编译器不允许我重载两个名称相同但返回类型不同的方法,特别是:
map <string, T > getNext()
{
// converts the values of getNext() return map into the specified type T
return convertedMapWithValuesOfTypeT;
}
这种情况下的解决方案是什么?我想保持字符串和其他类型(基本上是数字类型,可以通过词法强制转换从字符串)的方法名称相同
语言不允许函数重载返回类型,因为在大多数情况下,不考虑返回类型函数重载解析。在这种情况下,你真的有三个可能的解决方式:
- 最简单的(因此在大多数情况下也是首选的解决方案)是只是给这两个函数取不同的名字:
- 最后,可以模拟返回的重载键入,如果你不介意一些额外的复杂性。要做到这一点,你仍然必须实现其他解决方案之一,但客户端代码我看不出来。基本上,您的
getNext()
函数必须返回a带有重载转换函数的代理,类似于:<>之前类代理{因素*我;公众:代理(factors&owner): myOwner(&owner) {}操作符std::map<std::string,>() const{返回直到-> getNextAsMapToString ();}std::string, T>() const{返回直到-> getNextAsMapToType ();}};代理getNext(){返回代理(*this);}之前客户端代码可以直接调用getNext()
,这取决于它们做的结果,无论是getNextAsMapToString
或getNextAsMapToType
将被调用。
getNextAsMapToType
和例如,getNextAsMapToString
。或者,你可以将函数声明为模板:<>之前template<typename标签;std::>之前然后,将此函数专门化为std::string
和T
(和for没有别的)。用户必须指定getNext<std::string>()
或者getNext<...>
打电话给他想要的人。一般来说,我觉得这个比以前的解决方案,但它可能适用于模板,其中名称应该包含或至少暗示类型的名称。您可以使用[typeid
]在getNext
中添加运行时检查(http://en.cppreference.com/w/cpp/language/typeid)查看T
是否为字符串
类似:
template <typename T>
class Factors
{
public:
Factors(){};
deque<string> stringsDeck;
// some methods and variables here
map <string, T> getNext();
{
if (typeid(T) == typeid(string))
{
// Special handling for strings
}
else
{
// Do something else for other types
}
}
};
编辑
正如fschoenm所建议的,模板专门化可能更好:
template <typename T>
class Factors
{
public:
Factors(){};
// some methods and variables here
map <string, T> getNext();
};
template <>
class Factors<string>
{
public:
Factors(){};
deque<string> stringsDeck;
// some methods and variables here
map <string, string> getNext();
};
相关文章:
- 如何获取std::result_of函数的返回类型
- 奇怪的结构&GCC&clang(void*返回类型)
- 如何建立使用模板函数的lambda函数的尾部返回类型
- 为什么与常规GCC不同,即使有"学究性错误",MinGW-GCC也能容忍丢失的返回类型
- 在没有定义返回类型的函数中返回布尔值,并将结果保存在无错误的char编译中-为什么
- 特征::矩阵<双精度,1,3> 结构类型函数中的返回类型函数
- 函数作为模板参数,是否对返回类型强制约束
- C++中函数的向量返回类型引发错误
- 检查函数返回类型是否与STL容器类型值相同
- 为什么返回类型中需要typename?C++
- <Windows>为什么 std::thread::native_handle 返回类型为"long long unsigned int"的值,而不是 void*(又名 HANDLE)?
- 警告:在函数返回类型 [-Wignore 限定符] 时忽略类型限定符
- 为什么 c++(g++) 不允许模板返回类型和函数名称之间有空格?
- 为什么返回类型的'const'限定符对标有 __forceinline/内联的函数没有影响?
- 推导 std::vector::back() 的返回类型
- 在 c++ 中将函数返回类型指定为模板参数
- 使用 SWIG 更改生成的 CS 函数中的返回类型
- "无法封送'返回值':无效的托管/非托管类型组合",同时使用字符串数组封送委托
- 组合 std::forward、std::move 和 voltile 时出现意外的返回类型
- c++模板与STL返回类型的组合