如果 std::move 用作 &&&参数的参数,它是否会调用复制运算符?
Does std::move invoke the copy operator if it's used as an argument on a && parameter?
这是我的代码:
#include <iostream>
class carl{
public:
int x;
carl(int y):x(y){
}
carl(carl&& other)
{
std::cout<<" cons called?"<<std::endl;
this->x = other.x;
other.x = 0;
}
void operator=(carl&& other){
std::cout<<"operator called?"<<std::endl;
this->x = other.x;
other.x = 0;
}
};
void funct(carl&& get){
std::cout<<get.x<<std::endl;
}
int main(int argc, char** argv) {
carl c(2);
funct(std::move(c));
std::cout<<c.x<<std::endl;
return 0;
}
输出:
2
2
如果我还记得的话,有一条针对特殊成员函数的特殊规则规定,如果一个类声明了移动构造函数/运算符,那么该类将不会自动生成复制运算符/构造函数。
根据我的示例,移动运算符和构造函数似乎没有被调用,而是复制了值。它本应清空c'x
的值,并进行cout
来确认,但这些都没有发生。有人能澄清我的代码发生了什么吗?
您的代码中没有发生任何移动。func
将引用作为参数,因此传递std::move(c)
只是绑定引用——不会发生复制或移动。关键的事实是std::move
不会移动,它只是返回一个指定对象的右值。如果您按值计算参数:
void func(carl get);
然后,您将创建一个新对象,该对象使用move构造函数进行初始化(假设您将右值传递给func
)。
例如,这里的
void funct(carl&& get) { std::cout<<get.x<<std::endl; }
给出与完全相同的行为
void funct(carl& get) { std::cout<<get.x<<std::endl; }
即:传递对函数的引用。
只有当将右值引用移动到新对象中时,情况才会发生变化:
void funct(carl&& get)
{
auto my_carl = std::move(get);
std::cout<<my_carl.x<<std::endl;
}
然后编译器调用carl
的move构造函数将内容移出对象,而不是进行复制。
相关文章:
- 当对话框被接受时,如何用参数调用槽
- 使用用户定义的参数调用future/async并调用类方法
- 我使用向量来创建类对象列表.初始化向量时如何使用参数调用构造函数?
- 将成员函数作为构造函数参数调用时出错 "Variable is not a type name"
- 不允许运算符 const 参数调用 const 成员函数
- 为变量模板的每个参数调用模板函数
- 如何在窗口中使用注入的 dll 中的参数调用函数
- 按引用调用与按指针参数调用的差异 前递增和后递增
- 为什么使用不匹配的参数调用重载函数仍然有效
- PowerShell 使用结构类型参数调用 C++ DLL 的导出函数
- 基于枚举参数调用专用模板方法
- C++ 如何根据作为输入传递的参数调用一个构造函数或另一个构造函数?
- 如何使用类模板参数来更改参数调用和函数签名?
- lambda 函数使用其参数作为模板参数调用模板函数
- Android:使用 c++ 中的 byte[] 参数调用 java 方法
- 使用不同的模板参数调用模板类的对象
- C++编译时检查是否可以用某种类型的参数调用重载函数
- 是否可以基于类模板的参数调用类方法和全局方法
- 使用单独的参数调用"boost::process::system()"时,获取"execv
- C++大括号初始值设定项作为参数调用不同的构造函数,然后预期