0

所以我用 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 ##

4

0 回答 0