如果函数返回decltype(auto)并返回int &&类型的局部变量,为什么返回类型为int&?
如果我将变量转换为自己的类型,那么返回类型就是我期望的(int &&)
#include <utility>
namespace{
auto i = 5;
auto j = 5;
decltype(auto) foo1(){
int&& ret = std::move(i);
return ret;
}
decltype(auto) foo2(){
int&& ret = std::move(j);
return static_cast<decltype(ret)>(ret);
}
}
int main(){
static_assert(std::is_same_v<decltype(foo1()),int&>);
static_assert(std::is_same_v<decltype(foo2()),int&&>);
}
答案 0 :(得分:3)
这似乎是GCC中的错误。由于decltype(ret)
为int&&
,因此foo1
的返回类型为int&&
。但是,这立即导致foo1
格式不正确,因为返回int&&
的函数不能从ret
初始化返回值,这是一个左值(您将需要std::move
使它正常工作)。请注意,Clang拥有此权利(请参见问题注释中的链接)。