C++ 11 新特性:标准库move函数

本文介绍了C++11中的std::move函数,它用于将左值转换为右值引用,使得资源转移成为可能。文章讨论了移动构造函数和移动赋值运算符,强调它们在不分配新资源且通常不抛出异常的情况下“窃取”资源。移动操作后,源对象可能被销毁,因此需要确保moved-from对象处于可析构状态。此外,文章还提到了合成移动操作的条件以及何时应使用std::move。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

标准库move函数

我们可以通过调用std::move函数来获得绑定到左值上的右值引用,此函数定义在头文件<utility>中。std :: move用于指示对象obj可以“移动”,即允许资源从obj到另一个对象的有效传输。注意,对move我们不应该使用using声明,而是应该直接调用std::move而不是move,以避免名字冲突。

int && rr3 = std::move(rr1);

move告诉编译器:我们有一个左值,但我们希望像一个右值一样处理它。我们必须认识到,调用move就意味着:除了对 rr1 赋值或销毁外,我们再使用它。在调用move之后,我们不能对moved-from对象(即rr1)做任何假设。

#include <iostream>
#include <utility>
#include <vector>
#include <string>
 
int main()
{
   
   
    std::string str = "Hello";
    std::vector<std::string> v;
 
    // uses the push_back(const T&) overload, which means 
    // we'll incur the cost of copying str
    v.push_back(str);
    std::cout << "After copy, str is \"" << str << "\"\n";
 
    // uses the rvalue reference push_back(T&&) overload, 
    // which means no strings will be copied; instead, the contents
    // of str will be moved into the vector.  This is less
    // expensive, but also means str might now be empty.
    v.push_back(std::move(str));
    std::cout << "After move, str is \"" << str << "\"\n";
 
    std::cout << "The contents of the vector are \"" << v[0]
                                         << "\", \"" << v[1] << "\"\n";
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值