类方法的返回类型推导?C++1y.
Return type deduction for class methods? C++1y
c++14 中的成员函数允许返回类型推导,还是只允许自由函数返回类型推导?
我问是因为我有点隐含地假设它会工作,但在 gcc 4.8.1 中,我得到一个内部编译器错误("in gen_type_die_with_usage")。我第一次遇到这样的神秘错误,所以我有点怀疑;我知道从那时起他们已经改变了规格。
为了清楚起见,这对我有用:
auto foo() {return 5;}
但这不会:
class Bar{
auto baz() {return 5;}
}
标准草案中是否允许这样做?
是的,根据论文 n3582,标准应该允许它。这是论文中的一个例子。
允许具有自动返回类型的非定义函数声明并不是绝对必要的,但它对于喜欢在类外部定义成员函数的编码样式很有用:
struct A {
auto f(); // forward declaration
};
auto A::f() { return 42; }
如果我们在这种情况下允许它,它在其他情况下也应该有效。允许它也是更正交的选择;总的来说,我相信如果结合两个功能可以工作,它应该可以工作。
根据@bamboon的评论,"返回类型扣除仅在 gcc 4.9 开始支持",所以这可以解释为什么你没有它。
相关文章:
- 如何获取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:错误:未知方法返回类型:自定义类型
- 类方法的返回类型推导?C++1y.
- 如何在c++1y中保留cv限定符或返回类型推导中的引用