为什么在最后一行也没有调用复制构造函数
Why is copy constructor also not invoked in the last line?
这是一个有3个不同构造函数的类定义,一个默认构造函数,一个整型参数化构造函数和一个复制构造函数。r值对象是在创建之后创建和操作的。前两种情况按预期工作,但在最后一种情况中,预计会调用两个构造函数,但只调用第一个。为什么如此?代码如下:
#include <iostream>
using namespace std;
class A
{
int i;
public:
A() {cout << "In default ctorn";};
A(int v) {cout << "Setting i in par-ctor to " << v << "n"; i=v;}
A(const A& o) {cout << "In copy ctor, changing i to " << o.i << "n"; i=o.i;}
void print() {cout << "i = " << i << endl;}
};
int main()
{
A o(10);
A(o).print(); // invokes copy constructor A(const A&) as expected
A(20).print(); // invokes int parametrized constructor A(int)
A(A(30)).print(); // invokes only int constructor A(int) and not copy constructor, why so?
return(0);
}
输出为:
Setting i in par-ctor to 10
In copy ctor, changing i to 10
i = 10
Setting i in par-ctor to 20
i = 20
Setting i in par-ctor to 30
i = 30
c++标准明确允许编译器在某些情况下省略副本。这就是所谓的拷贝省略。其中一种情况如您所示:
如果要将未绑定到引用(12.2)的临时类对象复制/移动到具有相同cv- undefined类型的类对象,则可以通过将临时对象直接构造为省略的copy/move
的目标来省略复制/移动操作。
注意copy省略是可选的。您的编译器碰巧将这一行视为A(30).print();
,但它不必这样做。
相关文章:
- 在c++中使用向量时,如何调用构造函数和析构函数
- C++:考虑但不调用构造函数的特殊性
- 对象实例化调用构造函数的次数太多
- 我使用向量来创建类对象列表.初始化向量时如何使用参数调用构造函数?
- C ++:通过大括号调用构造函数?
- 不能调用构造函数
- 赋值 boost::intrusive_ptr 而不调用构造函数?
- 在模板化类的构造函数中调用构造函数
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- 为什么从另一个构造函数内部调用C++构造函数不修改类变量?
- 静态 std::map instatiation 在类的方法中调用构造函数吗?
- 有没有一种简单的方法可以在对象向量上调用构造函数?
- 我不明白在这个例子中什么时候调用构造函数
- 调用c++构造函数的不同方法
- 调用构造函数与将内联常量定义为默认参数
- 如何通过 Rust FFI 调用C++构造函数?
- "new"运算符是否总是调用构造函数?
- 无法调用构造函数
- 使用 "()" 调用构造函数不同于"{}"
- 确定是调用构造函数还是强制转换运算符的因素