为什么析构函数被调用两次,而构造函数只被调用一次
Why is the destructor getting called twice but the constructor only once?
我的代码是
class CTemp{
public:
CTemp(){
printf("nIn cons");
}
~CTemp(){
printf("nIn dest");
}
};
void Dowork(CTemp obj)
{
printf("nDo work");
}
int main()
{
CTemp * obj = new CTemp();
Dowork(*obj);
delete obj;
return 0;
}
我得到的输出是
In cons
Do work
In dest
In dest
为什么构造函数被调用一次,而析构函数被调用两次?有人能解释一下吗?
void Dowork(CTemp obj)
这里将进行本地复制,从DoWork
函数的作用域退出后将进行析构函数,这就是您看到析构函数调用的原因。
实现一个复制构造函数并再次检查:
CTemp(const CTemp& rhs){
printf("nIn copy cons");
}
当函数被调用时,它的参数是通过使用隐式复制构造函数创建的。将以下复制构造函数添加到您的类中
CTemp( const CTemp & ){
printf("nIn ccons");
}
查看关于创建对象的另一条消息
相关文章:
- 在c++中使用向量时,如何调用构造函数和析构函数
- C++:考虑但不调用构造函数的特殊性
- 对象实例化调用构造函数的次数太多
- 我使用向量来创建类对象列表.初始化向量时如何使用参数调用构造函数?
- C ++:通过大括号调用构造函数?
- 不能调用构造函数
- 赋值 boost::intrusive_ptr 而不调用构造函数?
- 在模板化类的构造函数中调用构造函数
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- 为什么从另一个构造函数内部调用C++构造函数不修改类变量?
- 静态 std::map instatiation 在类的方法中调用构造函数吗?
- 有没有一种简单的方法可以在对象向量上调用构造函数?
- 我不明白在这个例子中什么时候调用构造函数
- 调用c++构造函数的不同方法
- 调用构造函数与将内联常量定义为默认参数
- 如何通过 Rust FFI 调用C++构造函数?
- "new"运算符是否总是调用构造函数?
- 无法调用构造函数
- 使用 "()" 调用构造函数不同于"{}"
- 确定是调用构造函数还是强制转换运算符的因素