C++11 在特定情况下避免冗余返回类型
C++11 Avoiding Redundant Return Type in specific Situation
好的,感谢所有看过这篇文章的人。我已经在下面的链接中重新创建了确切的场景以便于查看,所以我只是注释掉我拥有的原始文本,因为它不清楚。http://cpp.sh/5lp4l
在注释部分,我显示了调用make_some(32, std::string{"hi"}),但没有为调用指定数据类型声明。我意识到这似乎很疯狂,并且远远超出了我的预期用例,根据参数自动推断复合类型(根据 int/string 推断我想要的数据)是没有必要的,或者是一个好主意。
编译器是对的。T
和Args
之间没有任何关系。因此,它无法确定QueryResult<T>
的含义。
您显然期望的是somefn
力的返回类型T
int, int
。这显然是不可能的,原因有两个:T
表示单一类型,并且没有机制使return
语句以某种方式影响make_some
的模板实例化。
您是否尝试过使用 auto
作为类型声明?
此外,decltype (variable_here) variable_to_inherit_type;
将第二个变量的类型设置为第一个变量的类型。您可以首先使用它来设置与传入变量相同的类型。
我不确定这是否适用于您的情况,但让我知道它是否有帮助!
相关文章:
- 如何获取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 函数中的返回类型
- 联合类型定义中的冗余字节
- C++11 在特定情况下避免冗余返回类型
- 为什么std::queue允许冗余类型规范