未使用复制构造函数
Copy-constructor is not used
我对C++和学习复制构造函数相对陌生。在这个简单的例子中,我想检查显式定义的复制构造函数是否真的是活动的。我在那里放了一根细绳,但我看不出它是印刷的。
问题:我想知道,为什么没有使用复制构造函数?由于在main
函数体中进行对象的复制
Person timmy_clone = timmy;
这是完整的代码:
#include <iostream>
class Person {
public:
int age;
Person(int a) {
this->age = a;
}
Person(const Person& person) {
std::cout << "hellon";
}
};
int main() {
Person timmy(10);
Person sally(15);
Person timmy_clone = timmy;
std::cout << "timmy age " << timmy.age << " " << "sally age " << sally.age << " " << "timmy_clone age " << timmy_clone.age << std::endl;
timmy.age = 23;
std::cout << "timmy age " << timmy.age << " " << "sally age " << sally.age << " " << "timmy_clone age " << timmy_clone.age << std::endl;
std::cout << &timmy << std::endl;
std::cout << &timmy_clone << std::endl;
}
编辑:我使用MinGW并使用-o编译
g++main.cpp-o main.exe
edit2:这是另一个代码片段,其中使用了显式定义的复制构造函数。仍然想知道为什么在这里使用它而不是在第一个例子中?
#include <iostream>
class Array {
public:
int size;
int* data;
Array(int sz)
: size(sz), data(new int[size]) {
}
Array(const Array& other)
: size(other.size), data(other.data) {std::cout <<"hellon";}
~Array()
{
delete[] this->data;
}
};
int main()
{
Array first(20);
first.data[0] = 25;
{
Array copy = first;
std::cout << first.data[0] << " " << copy.data[0] << std::endl;
} // (1)
first.data[0] = 10; // (2)
std::cout << "first data[0]: " << first.data[0];
}
您的代码正在按预期工作。请参见此处。
也许你混淆了copy-elision
,它在这里不适用。
相关文章:
- C++17复制构造函数,在std::unordereded_map上进行深度复制
- 为什么在C++中使用私有复制构造函数与删除复制构造函数
- 当从函数参数中的临时值调用复制构造函数时
- 如果有一个模板构造函数只有一个泛型参数,为什么我必须有一个复制构造函数
- 使用复制构造函数复制双精度数组
- C 无可行的构造函数复制类型的变量
- 没有可行的构造函数复制类型 'MyString' 的数组元素
- 编译时,复制构造函数/复制分配和正常功能调用优化之间是否存在任何区别
- 如何最小化调用列表构造函数(复制构造函数)的次数?
- C 11矢量构造函数复制与范围
- 我定义了一个非复制构造函数;复制构造函数还会被隐式定义吗
- 可以将构造函数复制为转换运算符
- 将基类指针的构造函数复制到子类
- C++树类:构造函数/复制/内存泄漏
- 如何制作这个在模板构造函数复制中使用类型定义的类型的模板
- 将构造函数复制为模板化的成员函数
- 绕过私有复制构造函数/复制赋值C++
- C++通过构造函数复制对象
- 复制构造函数 - 复制C++中的对象
- 将带unique_ptr的类的构造函数复制到作为成员的抽象类