- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
第一次,代码如下:
#include "stdafx.h"
#include<iostream>
using namespace std;
class Test{
public:
explicit Test(int);
~Test();
//Test(Test&);
int varInt;
};
Test::Test(int temp){
varInt = temp;
cout << "call Test::constructor\n";
}
Test::~Test(){
cout << "call Test::destructor\n";
}
/*Test::Test(Test&temp){
varInt = temp.varInt;
cout << "call Test::copy constructor\n";
}*/
void func(Test temp){
cout << "call func\n";
}
int _tmain(int argc, _TCHAR* argv[])
{
func(Test(1));
return 0;
}
输出:
call Test::constructor
call func
call Test::destructor
call Test::destructor
这让我很困惑,因为只创建了一个对象(作为 func 的参数),但是在函数结束后调用了两个析构函数。我开始怀疑,这是因为调用了默认的复制构造函数吗?所以我写了复制构造函数的定义,这让事情变得更加奇怪。在我将上面看到的注释掉的代码,即复制构造函数的定义添加到类中之后,输出变成了这样:
输出:
call Test::constructor
call func
call Test::destructor
事情变得恰到好处。谁能给我解释一下这个现象?非常感谢。
最佳答案
编辑添加:顺便说一句,在您的带有显式复制构造函数的版本中,您的构造函数在采用非常量 引用方面是不寻常的。这实际上意味着无论如何都不能使用它,因为非常量引用不能绑定(bind)到临时 Test(1)
。我认为这种奇怪现象可能与您的编译器执行复制省略的原因有关。如果您将构造函数更改为采用常量 引用,就像隐式声明的复制构造函数那样,您可能会看到预期的行为,即显式复制构造函数被调用并且析构函数被调用两次。 (但这只是我的猜测;您必须尝试看看!)
关于c++ - 为什么在这种情况下只调用一个构造函数而调用两个析构函数?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39462412/
我开始考虑在我 future 的项目或重构中实现控制反转容器,我想知道在正确设计依赖项时哪些原则(除了 GoF 模式)可能需要牢记在心。假设我需要构建一个简单的控制台应用程序,如果它可以访问互联网,它
假设我有一个 RxC contingency table 。这意味着有 R 行和 C 列。我想要一个维度为 RC × (R + C − 2) 的矩阵 X,其中包含行的 R − 1 “主效应”以及列的
我正在尝试使用 DKMS 为正在运行的内核 (4.4) 构 build 备树覆盖。我天真的 Makefile 如下: PWD := $(shell pwd) dtbo-y += my-awsome-o
我有一个 sencha touch 项目。我是用 phonegap 2.9 构建的,并且可以正常工作 device.uuid 返回到设备 ID。当我尝试使用 3.1 device.uuid 构建时抛出
我在安装了 Xcode 4.5.1 的 Mt Lion 上运行。 默认情况下,当我构建并部署到 iOS 5.1 设备时,显示会在我旋转设备时旋转,但当我部署到 iOS 6 模拟器或运行 iOS 的 i
我正在尝试使用 Google Analytics Reporting API v4 构建多折线图。 一张图表,其中我按每天的 session 计数为每个设备(台式机/平板电脑/移动设备)设置了一条线。
我一生都无法使用 xcode 组织者“自动设备配置”中的“团队配置配置文件”在 xcode 4.0.1 中将我的应用程序构建到我的 iPad 上。 该应用程序完美地构建到模拟器,但当我构建到 iPad
我是一名优秀的程序员,十分优秀!