C++拷贝构造函数与赋值函数

来源:互联网 发布:淘宝国际有假货吗 编辑:程序博客网 时间:2024/05/17 09:12

C++拷贝构造函数与赋值函数

 

C++的拷贝函数和赋值函数既有联系又有区别,不细究的话很容易搞混,遂以小例示之如下,权作解惑之用

 

// test.cpp

#include <iostream>

#include <stdlib.h>

#include <algorithm>

using namespace std;

 

class Book

{

public:

  Book(const char *name, const char*author, const double price): price(price) {

    this->name = new char[strlen(name)+1];

    this->author = new char[strlen(author)+1];

 

    strcpy(this->name, name);

    strcpy(this->author,author);

  }

 

  Book(const Book& book){            //拷贝构造函数

    name = new char[strlen(book.name)+1];

    author = new char[strlen(book.author)+1];

 

    price = book.price;

    strcpy(name, book.name);

    strcpy(author, book.author);

  }

 

  Book& operator=(const Book& rhs) {          //赋值构造函数

    Book(rhs).swap(*this);           // 先创建临时对象Book(rhs), 再调用下面的swap进行数据交换,

                                                  // 注意与*this交换数据的是临时对象, rhs并未修改,只是swap

                                                  // 结束后临时对象拥有了*this的数据, 而*this也拥有了由rhs

                                                  // 构造的临时对象的数据, 临时对象生命期结束时,*this的数据

                                                  // 会被销毁。

    return *this;                            

  }

 

  ~Book(){

    delete[] name;

    delete[] author;

  }

 

private:

  Book& swap(Book& rhs) {

    double temp = rhs.price;

    rhs.price = price;

    price = temp;

 

    std::swap(name, rhs.name); // std::swap()只是简单的交换指针的值

    std::swap(author, rhs.author);

    return *this;

  }

 

public:

  char* name;

  char* author;

  double price;

};

 

int main() {

  Book a("The C++ standard library", "Nicolai M. Josuttis", 98);

  Book b = a; // 对象b不存在, 拷贝构造函数在这里被调用

 

  Book c("Emacs Lisp manual", "stallman", 0);

  c = a; // c对象已经存在, 赋值函数(operator=)在这里被调用

 

  cout << a.name << endl;

  cout << a.author << endl;

  cout << a.price << endl << endl;

 

  cout << b.name << endl;

  cout << b.author << endl;

  cout << b.price << endl << endl;

 

  cout << c.name << endl;

  cout << c.author << endl;

  cout << c.price << endl;

}

 

编译:

g++ -o test test.cpp

 

运行结果:

The C++ standard library

Nicolai M. Josuttis

98

 

The C++ standard library

Nicolai M. Josuttis

98

 

The C++ standard library

Nicolai M. Josuttis

98