所以我用 C++ 11 写了一段代码
#include <iostream>
using namespace std;
void print (int &&a)
{
cout<<"rval ref";
}
void print (const int& a)
{
cout<<"const ref";
}
int main()
{
print(9);
}
代码的输出令人着迷,它是“rval referencence”但是如果我重写代码只是删除一个函数定义:
#include <iostream>
using namespace std;
void print (const int& a)
{
cout<<"const ref";
}
int main()
{
print(9);
}
我得到输出为“const ref”
编辑:如果我再次将代码重写为
#include <iostream>
using namespace std;
void print (int &&a)
{
cout<<"rval ref";
}
void print (const int&& a)
{
cout<<"const ref";
}
int main()
{
print(9);
}
仍然是打印“rval ref”,请解释逻辑
有人可以解释为什么 C++ 在传递 ravlue 作为参数时优先使用 && 而不是 const 吗?## Heading ##