C++中模板内部的返回类型可以控制吗
Can the return type inside templates in C++ be controlled?
我有一个类似于的模板函数
template<class T>
T foo( string sReturnType )
{
//pseudo code
if( sReturnType = "string" )
{
lookup data in string table
return a string
}
else
{
look up in number table
return number answer
}
}
用法类似于:foo("string")
在函数内部,需要有从字符串表或数字表中提取并返回该值的逻辑。我玩了这个,没能像我预期的那样发挥作用。它看起来应该非常简单明了。这是一种有效的方法和模板的使用吗?我研究了模板专业化,但最终你会编写两个独立的代码库,为什么不使用重载函数呢?有更好的方法吗?
否-无法声明具有不同返回类型的函数(模板函数可能具有不同的返回类型,但这些类型取决于模板参数)。
您可以返回一个封装所有可能的返回类型的类型(如boost::any或boost::variant)。
您必须重载foo()
;几乎没有办法绕过它。
std::string foo( std::string )
{
// look up data...
return std::string();
}
int foo( int )
{
// look up data...
return -1;
}
int i = foo( 1 );
std::string s = foo( "string" );
相关文章:
- 如何获取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 函数中的返回类型
- QtQuick - qml:28:错误:未知方法返回类型:自定义类型
- 错误:控制到达非空函数的末尾 [-Werror=返回类型] } ^
- C++中模板内部的返回类型可以控制吗