C ++调用默认构造函数而不是复制构造函数

时间:2015-12-18 13:58:42

标签: c++ oop constructor

我正在尝试为我的Arduino编写程序,但在将Item对象传递给另一个Holder对象时,我不会理解发生的事情。我构建了一个简单的例子:

class Item {
  public:
    int property;

    Item() {
      Serial.println("parameterless constructor called");
      this->property = 2;
    }

    Item(int property) {
      this->property = property;
      Serial.println("right constructor called");
    }
};

class Holder {
  public:
    Item someitem;

    Holder(Item& someitem) {
      this->someitem = someitem;
    }
};

void setup() {
  Serial.begin(9600);

  Item someitem = Item(1);
  Serial.println(someitem.property);

  Holder hold = Holder(someitem);
  Serial.println(hold.someitem.property);
}

void loop() {

}

控制台上的输出是:

right constructor called
1
parameterless constructor called
1

我不明白为什么首先调用无参数构造函数(我没有根据我的理解创建一个新对象),以及为什么它既不会改变当前对象也不会创建一个新对象一。编译器阻止了无参数构造函数。

1 个答案:

答案 0 :(得分:15)

您忘记了我们如何在C ++中初始化类成员 - member initializer lists

Holder(Item const& someitem) : someitem(someitem) {}

在您的代码中,someitem首先是默认构造的(在执行进入构造函数的{}块之前),然后您使用赋值运算符。

不调用复制构造函数(并且它不能在已构造的对象上)。