这是怎么MyClass
定义拷贝构造函数:为什么被用来代替赋值运算符
class MyClass {
double x, y;
public:
MyClass (double a = 0., double b = 0.) {
x = a;
y = b;
cout << "Using the default constructor" << endl;
}
MyClass (const MyClass& p) {
x = p.x;
y = p.y;
cout << "Using the copy constructor" << endl;
}
MyClass operator =(const MyClass& p) {
x = p.x;
y = p.y;
cout << "Using the assignment operator" << endl;
return *this;
}
};
我测试时,每个构造函数或方法被称为在我的主要程序:
int main() {
cout << "MyClass p" << endl; MyClass p; cout << endl;
cout << "MyClass r(3.4)" << endl; MyClass r(3.4); cout << endl;
cout << "MyClass s(r)" << endl; MyClass s(r); cout << endl;
cout << "MyClass u = s" << endl; MyClass u = s; cout << endl;
cout << "s = p" << endl; s = p; cout << endl;
}
为什么在第四个示例中使用的复制构造函数是MyClass u = s
而不是赋值运算符?
编辑
包括输出,问道:
MyClass p
Using the default constructor
MyClass r(3.4)
Using the default constructor
MyClass s(r)
Using the copy constructor
MyClass u = s
Using the copy constructor
s = p
Using the assignment operator
Using the copy constructor
因为语言指定'Type var = value'调用'Type'的拷贝构造函数而不是它的赋值操作符。 –
包括你的程序的输出会很好。 – MondKin
请注意,复制构造函数不需要被调用。编译器可以优化它(参见[Copy elision](http://en.wikipedia.org/wiki/Copy_elision))。这是编译器优化不会改变程序的可观察行为(在您的情况下是'cout'语句)的规则的一个例外。 – jrok