美文网首页
c++移动构造

c++移动构造

作者: Thinkando | 来源:发表于2018-10-06 21:36 被阅读30次

移动构造

  1. C++ 11 标准中提供了一种新的构造方法--移动构造
  2. C++11 之前,如果要将源对象的状态转移到目标对象只能通过复制。在某些情况下,我们有没有必要复制对象----只需要移动他们
  3. 移动语义:源对象资源的控制权全部交给目标对象


    image.png
  4. 什么时候用移动构造?
  • 临时对象即将消亡,但里面的数据还是要用的,所以用移动构造


    image.png
    image.png
  • 移动构造,效率更高一些,把快要释放的资源转移


    image.png
    image.png

另一个有趣的例子

#include <iostream>
using namespace std;

class A {
public:
    int x;
    A(int x) : x(x)
    {
        cout << "Constructor" << endl;
    }
    A(A& a) : x(a.x)
    {
        cout << "Copy Constructor" << endl;
    }
    A& operator=(A& a)
    {
        x = a.x;
        cout << "Copy Assignment operator" << endl;
        return *this;
    }
    A(A&& a) : x(a.x)
    {
        cout << "Move Constructor" << endl;
    }
    A& operator=(A&& a)
    {
        x = a.x;
        cout << "Move Assignment operator" << endl;
        return *this;
    }
};

A GetA()
{
    return A(1);
}

A&& MoveA()
{
    return A(1);
}

int main()
{
    cout << "-------------------------1-------------------------" << endl;
    A a(1);  // 调用构造函数
    cout << "-------------------------2-------------------------" << endl;
    A b = a; // 创建新对象b,使用a初始化b,因此调用拷贝构造函数。
    cout << "-------------------------3-------------------------" << endl;
    A c(a); // 创建新对象c,使用a初始化c,因此调用拷贝构造函数。
    cout << "-------------------------4-------------------------" << endl;
    b = a; // 使用a的值更新对象b,因为不需要创建新对象,所以调用拷贝赋值运算符。
    cout << "-------------------------5-------------------------" << endl;
    A d = A(1); //创建新对象d,使用临时对象A(1)初始化d,由于临时对象是一个右值,所以调用移动构造函数。
    cout << "-------------------------6-------------------------" << endl;
    A e = std::move(a); //创建新对象e,使用a的值初始化e,但调用std::move(a)将左值a转化为右值,所以调用移动构造函数。
    cout << "-------------------------7-------------------------" << endl;
    A f = GetA(); // 创建新对象f,使用GetA()函数返回的临时对象初始化f,由于临时对象是右值,所以调用移动构造函数。值得注意的是,这里调用了两次移动构造函数。第一次是GetA()返回前,A(1)移动构造了一个临时对象。第二次是临时对象移动构造f。
    cout << "-------------------------8-------------------------" << endl;
    A&& g = MoveA(); // 没有创建新对象,也不更新任何对象,只是将MoveA()的返回值绑定到右值引用g。因此不调用构造函数,也不调用赋值运算符。
    cout << "-------------------------9-------------------------" << endl;
    d = A(1); // 使用临时对象A(1)更新d,因为不需要创建新对象,所以调用移动赋值运算符。
    

}
-------------------------1-------------------------
Constructor
-------------------------2-------------------------
Copy Constructor
-------------------------3-------------------------
Copy Constructor
-------------------------4-------------------------
Copy Assignment operator
-------------------------5-------------------------
Constructor
-------------------------6-------------------------
Move Constructor
-------------------------7-------------------------
Constructor
-------------------------8-------------------------
Constructor
-------------------------9-------------------------
Constructor
Move Assignment operator
Program ended with exit code: 0

参考文献

  1. https://www.jianshu.com/p/f5d48a7f5a52

相关文章

  • C++中为什么move construct需要加noexcept

    C++ 11中增加了名为移动构造函数的构造函数类型。通过使用移动构造函数,我们可以在进行对象复制时直接“窃取”拷贝...

  • c++移动构造

    移动构造 C++ 11 标准中提供了一种新的构造方法--移动构造 C++11 之前,如果要将源对象的状态转移到目标...

  • C++拷贝控制

    前言 C++通过在类中定义几个成员函数来控制的对象的拷贝,移动,赋值和销毁,分别如下: 拷贝构造函数和移动构造函数...

  • C++11六大函数(构造函数,移动构造函数,移动赋值操作符,复制

    在C++中,有三大函数复制控制(复制构造函数,赋值操作符,析构函数),而在C++11中,加入了移动构造函数,移动赋...

  • [C++11阅读]继承构造函数和委派构造函数

    在我看来C++构造函数已经够复杂了,继承构造和委派构造,包括下一篇要提到的移动构造,使情况变得更复杂,对新手更不友...

  • windows逆向3

    VC 程序内存和编译的一些特征C++ 构造函数C++ 成员函数C++ 析构函数C++ 全局对象的构造C++ 全局对...

  • [转载] 右值引用与移动构造

    右值引用与移动构造(上) 右值引用与移动构造(中) 右值引用与移动构造(下)

  • C++ 构造过程

    构造函数 C++中每个类必须有一个构造函数,如果用户没有自行编写构造函数,则C++会自动提供一个无参数的构造函数,...

  • C++小黄鸭课堂(3)多样的构造函数

    哪到底有哪些构造函数呢? 1、无参构造 2、有参构造 3、拷贝构造 4、移动构造(c++11) 看一段代码: 移动...

  • 第13章 拷贝控制

    拷贝控制成员函数:拷贝构造、拷贝赋值、移动构造、移动赋值、析构;不显式定义则编译器会生成合成版本。拷贝和移动构造函...

网友评论

      本文标题:c++移动构造

      本文链接:https://www.haomeiwen.com/subject/qyfkaftx.html