右引用左值
Right reference on lvalue
本文关键字:引用 更新时间:2023-10-16
什么时候右值成为左值的右引用?
示例如下,用std::forward
求解:
void g(int && v1, int & v2)
{
std::cout << v1 << " " << ++v2 << std::endl;
}
template <typename F, typename T1, typename T2>
void flip(F f,T1 && t1, T2 && t2){
g(t2, t1);
}
调用时出现如下错误:
flip(g, j, 2);
我的问题是:在flip(g, j 2)
中,第三个参数2
为右值。
在函数flip
中,参数t2
是对2的正确引用。当调用g
时,似乎t2
是对lvalue的正确引用。
在什么情况下,通过引用(没有复制?)接收的rvalue成为左值?
示例如下:https://ideone.com/cJvFCg
有一个"if it has a name"规则说,在这样的代码中,如果变量有一个名称(在这种情况下,你的t2
),那么在这一点上,它成为一个左值。(参见Scott Meyers Effective Modern c++)
为了保留调用者的原始意图,您确实应该使用完美转发:
g(std::forward<T2>(t2), ...)
相关文章:
- 将对象数组的引用传递给函数
- 什么时候在C++中返回常量引用是个好主意
- 我想将一个对T类型的非常量左值引用绑定到一个T类型的临时值
- 何时在引用或唯一指针上使用移动语义
- 如何在c++中使用引用实现类似python的行为
- 编译C++时未定义的引用
- Ctypes wstring通过引用传递
- c++r值引用应用于函数指针
- 理解c++中的引用
- C++取消引用指针.为什么会发生变化
- 如何修复此错误:未定义对"距离(浮点数,浮点数,浮点数,浮点数,浮点数)"的引用
- 我的项目不会像"undefined reference to `grpc::g_core_codegen_interface'"那样使用未定义的引用错误进行编译
- C++Boost Asio Pool线程,带有lambda函数和传递引用变量
- 强制转换为引用类型
- 引用一个已擦除类型(void*)的指针
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么
- 具有默认值的引用获取函数
- 如何使用基类指针引用派生类成员
- 使用取消引用的指针的多态性会产生意外的结果.为什么?
- 如何引用基类的派生类?