两种初始化有什么区别:Foo f();Foo f = Foo()
What is the difference between the two initialization: Foo f(); Foo f = Foo()
class Foo
{
public:
Foo(){}
private:
Foo(const Foo &);
};
Foo f();
Foo f1 = Foo();
我发现当我声明Foo(const Foo &)
私有时,Foo f1 = Foo();
不编译。所以我认为Foo f1 = Foo()
;只是调用复制构造函数,但是当我将代码更改为:
class Foo
{
public:
Foo(){}
Foo(const Foo &){std::cout<<"Foo(const Foo &)";}
};
Foo f();
Foo f1 = Foo();
它不打印任何东西。那么两种初始化有什么区别:Foo f(); Foo f = Foo()
?
由于复制省略,不必调用复制构造函数。但是,复制构造函数必须仍作为公共成员存在。
Foo f();
声明了一个名为f
的函数,不带任何参数,并按值返回一个Foo
对象。
要回答实际问题,正式地,代码
Foo f1 = Foo();
使用默认构造函数创建类型Foo
的临时对象,并使用复制构造函数构造f1
为该临时对象的副本,然后销毁临时对象。
Foo f;
使用默认构造函数创建f
。
与复制构造函数的小舞并不像听起来那么低效。在过去,只要复制构造函数是可访问的,编译器就可以跳过临时的,直接初始化f1
。这被称为"复制省略"。生成的代码与Foo f1;
相同。但是,如果Foo
没有复制构造函数,或者在初始化时无法访问构造函数(例如,复制构造函数是私有的,并且初始化未在成员函数内完成(,则代码无效。
然后,复制省略成为强制性的:编译器不再只是允许跳过临时的;这是必需的。
现在,显然,甚至不再需要复制构造函数存在并且可以访问;编译器需要将第一种形式转换为第二种形式,因此两者是相同的。
相关文章:
- 是否可以初始化不可复制类型的成员变量(或基类)
- C++使用整数的压缩数组初始化对象
- C++初始化基类
- 多成员Constexpr结构初始化
- 复制列表初始化的隐式转换的等级是多少
- 内联映射初始化的动态atexit析构函数崩溃
- 如何在C++中初始化嵌套类中的2个memeber
- 如何声明特征矩阵,然后通过嵌套循环初始化它
- 没有用于初始化C++中的变量模板的匹配构造函数
- 在未初始化映射的情况下,将值插入到映射的映射中
- C++成员初始化
- 为什么在C++中首先初始化成员类
- 同时具有"聚合初始化"和"模板推导"
- 初始化具有非默认构造函数的std::数组项的更好方法
- 是否可以在编译时初始化数组,以便在运行时不会花费时间?
- 我可以使用条件运算符初始化C风格的字符串文字吗
- 两种初始化有什么区别:Foo f();Foo f = Foo()
- 从类型为"foo*"的右值初始化类型为"foo*&"的非常量引用无效?
- std::shared_ptr 初始化:make_shared<Foo>() vs shared_ptr<T>(new Foo)
- 错误:跳转到标签"FOO"交叉初始化"条形"