这是一个简单的例子:
class A {
//...
public:
A (const A&, bool deep = false) {
if (!deep) { /* make a shallow copy */ }
else { /* make a deep copy */ }
}
};
void foo (A x) { /*...*/ }
A bar () { /*...*/ return A(); }
A a_var;
在此示例中,参数默认为 false,这意味着默认的复制构造函数将是浅的。
A b(a_var); // b gets a shallow copy of a
foo(b); // foo() receives a shallow copy
但是,可以通过在第二个参数中传入 true 来实现深层复制。
A b(a_var, true); // b gets a deep copy of a
foo(A(b, true)); // foo receives a shallow copy of a deep copy
类似地,对于返回 an 的函数A
,返回的副本将是浅的,因为它使用默认值,但接收者可以在接收到它时使其变得深。
A b(bar()); // shallow
A b(bar(), true); // deep
请记住,当您定义复制构造函数时,很可能意味着您需要定义析构函数并重载赋值运算符(三规则)。