当前位置:主页 > 软件编程 > C代码 >

c++ 移动构造相关总结

时间:2021-03-08 11:36:25 | 栏目:C代码 | 点击:

 下面随笔给出c++移动构造。

  在现实中有很多这样的例子,我们将钱从一个账号转移到另一个账号,将手机SIM卡转移到另一台手机,将文件从一个位置剪切到另一个位置……移动构造可以减少不必要的复制,带来性能上的提升。

                 源对象资源的控制权全部交给目标对象

问题与解决

当临时对象在被复制后,就不再被利用了。我们完全可以把临时对象的资源直接移动,这样就避免了多余的复制操作。

移动构造

                有可被利用的临时对象

     class_name ( class_name && )

//例:函数返回含有指针成员的对象(版本1)

//使用深层复制构造函数

//返回时构造临时对象,动态分配将临时对象返回到主调函数,然后删除临时对象。

#include<iostream>

using namespace std;

class IntNum {

public:

  IntNum(int x = 0) : xptr(new int(x)){ //构造函数

    cout << "Calling constructor..." << endl;

   }

  IntNum(const IntNum & n) : xptr(new int(*n.xptr)){//复制构造函数

    cout << "Calling copy constructor..." << endl;

  };

  ~IntNum(){ //析构函数

    delete xptr;

    cout << "Destructing..." << endl;

  }

  int getInt() { return *xptr; }

private:

  int *xptr;

};

//返回值为IntNum类对象

  IntNum getNum() {

    IntNum a;

    return a;

  }

int main() {

  cout<<getNum().getInt()<<endl;

  return 0;

}

//运行结果:

Calling constructor...

Calling copy constructor...

Destructing...

0

Destructing...
//例:函数返回含有指针成员的对象(版本2)

//使用移动构造函数

//将要返回的局部对象转移到主调函数,省去了构造和删除临时对象的过程。

#include<iostream>

using namespace std;

class IntNum {

public:

  IntNum(int x = 0) : xptr(new int(x)){ //构造函数

    cout << "Calling constructor..." << endl;

  }

  IntNum(const IntNum & n) : xptr(new int(*n.xptr)){//复制构造函数

    cout << "Calling copy constructor..." << endl;

   //注:

  //•&&是右值引用

  //•函数返回的临时变量是右值

  }

  IntNum(IntNum && n): xptr( n.xptr){ //移动构造函数

    n.xptr = nullptr;

    cout << "Calling move constructor..." << endl;

  }

  ~IntNum(){ //析构函数

    delete xptr;

    cout << "Destructing..." << endl;

  }

private:

  int *xptr;

};

//返回值为IntNum类对象

  IntNum getNum() {

  IntNum a;

  return a;

}

int main() {

  cout << getNum().getInt() << endl; return 0;

}

//运行结果:

Calling constructor...

Calling move constructor...

Destructing...

0

Destructing...

您可能感兴趣的文章:

相关文章