如何触发数据成员的复制构造函数
How can I trigger the copy constructor for data members?
我试过这个:
class cls1{
public:
cls1(){ cout << "cls1 constructorn";}
cls1 (cls1 & o){ cout << "cls1 copy constructorn";}
};
class cls2{
public:
cls2 () { cout << "cls2 constructorn";}
cls2 (cls2 & o){ cout << "cls2 copy constructorn";}
};
class my_cls{
public:
cls1 o1;
cls2 o2;
my_cls(){ cout << "my_cls constructorn";}
my_cls(my_cls& o){ cout << "my_cls copy constructorn";}
};
void f(my_cls o){}
int main(){
my_cls p;
f(p);
return 0;
}
但输出是:
cls1 constructor
cls2 constructor
my_cls constructor
cls1 constructor
cls2 constructor
my_cls copy constructor
我觉得这很令人困惑,因为我被告知,对于每个成员,复制构造函数在进行逐位复制时调用该成员的复制构造函数,对于高级类型执行。(我希望 cls1 和 cls2 的复制构造函数在 my_cls 的复制构造函数之前调用)
您被告知的内容仅适用于编译器生成的复制构造函数。
如果要编写自己的复制构造函数,则需要将成员和基类的副本 c-tor 放在初始化列表中,否则将使用它们的默认 c-tor。
在您的示例中,缺少: o1(o.o1), o2(o.o2)
:
der (der & o)
: o1(o.o1)
, o2(o.o2)
{ cout << "my_cls copy constructorn";}
实际上:
der (der & o){ cout << "my_cls copy constructorn";}
相当于
der (der & o):o1(),o2(){ cout << "my_cls copy constructorn";}
即,复制构造函数调用类类型成员的默认构造函数。
要使其按预期运行,请执行以下操作:
der (der & o):o1(o.o1),o2(o.o2){ cout << "my_cls copy constructorn";}
要使其语义正确:
der (der const& o)
它就像常规构造函数的初始化列表
class my_cls{
public:
cls1 o1;
cls2 o2;
my_cls (){ cout << "my_cls constructorn";}
my_cls (my_cls & o) : o1(o.o1), o2(o.o2) { cout << "my_cls copy constructorn";}
};
相关文章:
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 当从函数参数中的临时值调用复制构造函数时
- 如果有一个模板构造函数只有一个泛型参数,为什么我必须有一个复制构造函数
- 为什么需要复制构造函数,在哪些情况下它们非常有用
- 使用仅使用一次的变量调用的复制构造函数.这可能是通过调用move构造函数进行编译器优化的情况吗
- 为什么类中的ostringstream类型的成员会导致";调用隐含删除复制构造函数";错误
- 复制构造函数、赋值运算符C++
- std::ofstream 作为类成员删除复制构造函数?
- 复制构造函数C++无法正确复制指针
- 关于复制构造函数的一个棘手问题
- 为什么调用复制构造函数而不是移动构造函数?
- 填充上编译器生成的复制构造函数之间的不一致
- C++ 对象指针数组的复制构造函数
- C++ 基本 CTOR 说明 - 为什么不调用赋值/复制构造函数
- 防止在复制构造函数中隐式调用基构造函数
- 为用户定义的类正确调用复制构造函数/赋值运算符
- 具有已删除移动和复制构造函数的类的就地构造
- 复制构造函数隐式转换问题
- 复制构造函数中的递归调用