当使用std::forward时,为什么我可以在传递r值的同时调用l值引用函数
When using std::forward, why am I able to call an l-value reference function while passing in an r-value?
我目前正在研究r值引用和移动语义,在我自己的编码实验中发现了一个奇怪的差异。
给定以下代码:
#include <iostream>
using namespace std;
class X{};
void g(X&& t) // A
{
cout << "Rref call" << endl;
}
void g(X& t) // B
{
cout << "Lref call" << endl;
}
template<typename T>
void f(T&& t)
{
g(forward<T>(t));
}
int main()
{
X x;
f(x); // 1
f(X()); // 2
return 0;
}
将在此处生成预期输出:
Lref调用
Rref调用
然而,如果我继续删除重载的函数g,该函数使用r值引用(如上注释行//A所示),我将得到以下输出:
Lref调用
Lref调用
这是怎么回事?为什么编译器在尝试传入X&&
时不抱怨对g(X& t)
的调用?
当您注释掉g(X&& t)
重载时,您使用的是一个允许将右值绑定到非const
左值引用的MSVC扩展。如果将警告级别提高到/W4
,MSVC将告诉您正在使用非标准扩展。
gcc和clang都无法编译带有注释掉的重载的代码。
相关文章:
- 如何用参数值调用函数(仅在运行时已知)
- 从python中调用C++函数并获取返回值
- 当使用通配符和null指针调用函数时,对输出的说明
- 从R调用C++函数并对其进行集成时出错
- 使用QTreeView,如何通过调用函数只突出显示特定的行/列
- 如何在qt中从另一个类调用函数
- 在 COUT 语句中使用 COUT 调用函数
- 如何从线程中的不同模块调用函数?
- C++从函数指针数组调用函数
- 当 A 在 for 循环中调用函数 B 时,如何计算函数 A 的空间复杂度?
- 如何在 C/C++ 中从外部库调用函数
- 如何使用运算符在同一行中多次调用函数
- 是否可以创建一个从不同类调用函数的线程?
- 无法为类成员调用函数
- 如何从另一个标头 c++ 调用函数
- C++有什么方法可以在既不调用函数模板也不提供其模板参数的情况下引用函数模板?
- 如何只允许在调用函数 B 后调用函数 A?
- 我可以这样调用函数吗?
- 如何在 c++ 的类中递归调用函数方法?
- 为什么在指向对象的迭代器上调用函数不允许我更改对象本身?