移动语义在这里如何工作?
How move semantics works here?
我有以下示例,我不确定我是否完全理解移动语义逻辑:
#include <iostream>
#include <string>
#include <memory>
class Player
{
public:
Player(std::string name)
: m_name(std::move(name)) {}
private:
std::string m_name;
};
int main()
{
std::string s = "Zidane";
std::cout << s << std::endl;
Player player1(s); // not moved
std::cout << s << std::endl; // s = "Zidane"
Player player2(std::move(s)); // moved -> s is empty now
std::cout << s << std::endl;
return 0;
}
我的解释是,在第一种情况下(Player1
(,name
实际上是在调用m_name
的 ctor 之前复制的std::string
类型的左值,然后,std::move
作用于副本,所以最后副本是空的,其内容已使用 move ctor 移动到m_name
。这就是为什么最初的论点s
保持不变。正确吗?
在第二种情况下,不清楚:std::move
将左值参数转换为引用右值,然后从那里会发生什么?在这种情况下,参数 s 在调用后为空。
在调用Player(std::string name)
之前,始终会创建一个新std::string
来"填充"name
参数。
重载解析将指示是调用std::string
的复制 ctor 还是移动 ctor。
案例1:Player player1(s);
新字符串由带有签名basic_string( const basic_string& other );
的副本 ctor 创建,因为 's' 是一个左值。
您支付的总操作总和是字符串的 1 次移动和 1 次复制构造:
- 一个副本 ctor,用于将
name
参数复制到 ctor - 单步 ctor,用于
m_name
类成员
案例2:Player player2(std::move(s));
新字符串由 移动 ctor 创建,用于std::string
,并带有签名basic_string( basic_string&& other ) noexcept;
在第二种情况下,您调用std::move
,这会将s
转换为右值引用。std::string
有 2 个构造函数,一个采用const std::string&
,另一个采用std::string&&
。右值引用可以绑定到左值引用和右值引用,但右值引用版本是更好的匹配,因此将被选中。
您支付的总操作总和是字符串的 2 个移动结构:
- 一招 ctor,用于
name
参数到 ctor - 单步 ctor,用于
m_name
类成员
请注意,正如@aschepler和@underscore_d所指出的,std::string
的移动 ctor 不需要清除源字符串。不应依赖此行为,因为它无法保证,并且取决于字符串的移动 ctor 是如何实现的。
- QSqlquery prepare()和bindvalue()不工作
- 导入库可以跨dll版本工作吗
- 以螺旋方式打印矩阵的程序.(工作不好)
- 对象指针在c++中是如何工作的
- 为什么在Windows上的VS 2019和Clang 9中"size_t"在没有标题的情况下工作
- VSOMEIP-2个设备之间的通信(TCP/UDP)不工作
- 为字符串中每 N 个字符插入空格的函数没有按照我认为的方式工作?
- C++为线程工作动态地分割例程
- 为什么我的 std::ref 无法按预期工作?
- 布尔比较运算符是如何在C++中工作的
- SampleConsensusPrerejective(ext.RANSAC)是如何真正工作的
- 不确定要在我的main中放入什么才能使我的代码正常工作
- 为什么std::condition_variable notify_all的工作速度比notify_one快(对于随机请
- <<操作员在下面的行中工作
- 有人能解释一下为什么下界是这样工作的吗C++的
- ExtractIconEx:可以工作,但偶尔会崩溃
- C++中的memset函数工作不正常
- 当我在第一个循环中使用"auto"时,它工作正常,但是使用"int"它会给出错误,为什么?
- 当 int 方法工作正常时,void 方法有何不同,或者为什么我不能调用 void 方法?
- sdl软件渲染器不工作,工作在硬件加速的一个