c++11 移动语义

测试代码

#include <iostream>
using namespace std;

class Person
{
private:
    int age;
    string name;
    int* data;

public:
    Person() : data(new int[1000000]){}
    ~Person() { delete [] data; }

    // 拷贝构造函数
    Person(const Person& p) :
    age(p.age),
    name(p.name),
    data(new int[1000000]){
        std::copy(p.data, p.data+1000000, data);
        cout << "Copy Constructor" << endl;
    }

    // 拷贝赋值运算符
    Person& operator=(const Person& p){
        this->age = p.age;
        this->name = p.name;
        this->data = new int[1000000];
        std::copy(p.data, p.data+1000000, data);
        cout << "Copy Assign" << endl;
        return *this;
    }

    // 移动构造函数
    Person(Person &&p) :
    age(std::move(p.age)),
    name(std::move(p.name)),
    data(p.data){
        p.data=nullptr; // 源对象的指针应该置空,以免源对象析构时影响本对象
        cout << "Move Constructor" << endl;
    }

    // 移动赋值运算符
    Person& operator=(Person &&p){
        this->age = std::move(p.age);
        this->name = std::move(p.name);
        this->data = p.data;
        p.data=nullptr;
        cout << "Move Assign" << endl;
        return *this;
    }

    // 普通成员函数
    void PrintAge(){
        cout << "age:" << this->age << endl;
        cout << "data:" << this->data << endl;
    }
};

int main(){
    Person p1;
    Person p2 = p1; // 拷贝构造函数
    p1.PrintAge();
    p2.PrintAge();

    Person p3,p4;
    p3 = p4; // 拷贝赋值运算符
    p3.PrintAge();
    p4.PrintAge();

    Person p5;
    Person p6 = std::move(p5); // 移动构造函数
    p5.PrintAge();
    p6.PrintAge();

    Person p7,p8;
    p7 = std::move(p8); // 移动赋值运算符
    p7.PrintAge();
    p8.PrintAge();

    return 0;
}

实际应用代码:

CodePointMatcherWarehouse.png

image.png

这是node源码的一个CodePointMatcherWarehouse类,从上图的声明和定义看到这个类只有移动拷贝构造函数和移动赋值运算符,而没有拷贝构造函数和拷贝赋值运算符。
还有一个特殊的宏: U_NOEXCEPT

#ifdef U_NOEXCEPT
    /* Use the predefined value. */
#else
#   define U_NOEXCEPT noexcept
#endif

这就要求尽量保证移动构造函数、移动拷贝赋值运算符不发生异常;使用noexcept关键字,是为了保证移动构造函数中抛出来的异常会直接调用terminate终止程序。

总结

1、使用&&定义移动拷贝构造和移动赋值运算符;
2、调用时使用std::move函数;
3、移动的作用在于避免拷贝提高效率,并转移使用权。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 以下内容引自[wikipedia](https://zh.wikipedia.org/wiki) ### 什么是右...
    alenstar阅读 783评论 0 0
  • 3. 类设计者工具 3.1 拷贝控制 五种函数拷贝构造函数拷贝赋值运算符移动构造函数移动赋值运算符析构函数拷贝和移...
    王侦阅读 1,900评论 0 1
  • 演唱:小曲儿 若随风 往事不随风 它偶然飘落入梦中 前尘多少故事曾翻涌 那夜霜重露正浓 若生离难与他相逢 惟死别才...
    觉智师兄阅读 952评论 0 0
  • 1 前段时间,妈妈把家里的汤锅摔碎了,那是一个很普通的炖汤的陶瓷锅,她时常用它来熬骨头汤给我喝。 我听见后声音走进...
    张大雄bear阅读 472评论 1 2
  • 2年,她与他的婚姻只维持了2年。 也罢,他们的爱情本就没有结果。现在的局面也都是他们一手造成的。她...
    墨染CR阅读 234评论 0 0