为什么我的复制构造函数没有调用?

时间:2012-11-28 23:42:57

标签: c++ operator-overloading copy-constructor

  

可能重复:
  What are copy elision and return value optimization?

我有以下程序:

#include <iostream>

using namespace std;

class Pointt {
public:
    int x;
    int y;

    Pointt() {
        x = 0;
        y = 0;
        cout << "def constructor called" << endl;
    }

    Pointt(int x, int y) {
        this->x = x;
        this->y = y;
        cout << "constructor called" << endl;
    }

    Pointt(const Pointt& p) {
        this->x = p.x;
        this->y = p.y;
        cout << "copy const called" << endl;
    }

    Pointt& operator=(const Pointt& p) {
        this->x = p.x;
        this->y = p.y;
        cout << "op= called" << endl;
        return *this;
    }
};

Pointt func() {
    cout << "func: 1" << endl;
    Pointt p(1,2);
    cout << "func: 2" << endl;
    return p;
}


int main() {
    cout << "main:1" << endl;
    Pointt k = func();
    cout << "main:2" << endl;
    cout << k.x << " " << k.y << endl;
    return 0;
}

我期望的输出如下:

main:1
func: 1
constructor called
func: 2
copy const called
op= called
main:2
1 2

但我得到以下内容:

main:1
func: 1
constructor called
func: 2
main:2
1 2

问题是:为什么不将对象从func返回到main调用我的拷贝构造函数?

1 个答案:

答案 0 :(得分:5)

这是由于Return Value Optimization。这是允许C ++更改程序行为以进行优化的少数几个实例之一。