我对C++中的复制构造函数感到困惑
I'm confused about copy-constructor in C++
可能重复:
为什么在这种情况下不调用复制构造函数?
在下面的代码中,我构造了三个变量,a1、a2和a3。
C++Primer第476页中有一个例子:
string empty_copy = string();//copy-initialization
有人能帮我解释吗
1) 为什么a1和a2不是由复制构造函数和构造的
2) 我的代码中的初始化a2和书中的emptycopy之间有什么区别?
非常感谢!
#include<iostream>
using namespace std;
class A{
public:
A(){}
A(int v){}
A(const A&x){
cout<<"copy constructor"<<endl;
}
};
A generateA(){
return A(0);
}
int main(){
cout<<"First:"<<endl;
A a1=generateA();
cout<<"Second:"<<endl;
A a2=A(0);
cout<<"Third:"<<endl;
A a3=a1;
return 0;
}
输出是(在Win7中的Visual Studio 2010和Ubuntu110.10中的g++下):
First:
Second:
Third:
copy constructor
这是由于返回值优化而导致的复制省略
编译器可以通过应用这样的优化来优化副本的生成。
A a1=generateA();
A a2=A(0);
在以上两种情况下,编译器都可以取消创建临时对象,该对象是为保存返回值而创建的。
A a3=a1;
涉及用于构造a3
的已存在命名对象a1
,这涉及编译器必须进行且无法优化的复制构造函数调用。
编辑:回答评论中的问题。
您可以在编译过程中使用以下选项告诉编译器不要应用此优化:
对于GCC:
-fno-elide-constructors
对于MVSC:
/Od
-
在
a1
和a2
中不使用复制构造函数,因为在这两种情况下,您都在传递int
,因此编译器使用您定义的A(int)
构造函数。 -
你的例子和书中的例子的区别在于,书在堆栈上创建了一个实例(
string()
),因此得到了一个空副本,而在你的情况下,你使用的是一个现有的实例(a1
)。两者都在使用复制构造函数进行初始化。
初始化a1时,会有一个整数参数(在工厂函数中给定)。对于a2,还可以传递一个整数。对于a3,你说a3=a1。这被解释为a3(a1),因为您定义了一个复制构造函数,所以它被调用。
相关文章:
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 当从函数参数中的临时值调用复制构造函数时
- 如果有一个模板构造函数只有一个泛型参数,为什么我必须有一个复制构造函数
- 使用复制构造函数复制双精度数组
- C 无可行的构造函数复制类型的变量
- 没有可行的构造函数复制类型 'MyString' 的数组元素
- 编译时,复制构造函数/复制分配和正常功能调用优化之间是否存在任何区别
- 如何最小化调用列表构造函数(复制构造函数)的次数?
- C 11矢量构造函数复制与范围
- 我定义了一个非复制构造函数;复制构造函数还会被隐式定义吗
- 可以将构造函数复制为转换运算符
- 将基类指针的构造函数复制到子类
- C++树类:构造函数/复制/内存泄漏
- 如何制作这个在模板构造函数复制中使用类型定义的类型的模板
- 将构造函数复制为模板化的成员函数
- 绕过私有复制构造函数/复制赋值C++
- C++通过构造函数复制对象
- 复制构造函数 - 复制C++中的对象
- 将带unique_ptr的类的构造函数复制到作为成员的抽象类