#目的#:
对拷贝构造函数和析构函数进一步理解
代码:
#include <iostream>
#include <string>
using namespace std;
class File {
public:
// 构造函数
File(string _name, double _size) : name(_name), size(_size) {
cout << "创建文件:" << name << ",大小:" << size << "M" << endl;
}
// 拷贝构造函数
File(const File& other) : name(other.name + "(1)"), size(other.size) {
cout << "拷贝生成文件:" << name << ",大小:" << size << "M" << endl;
}
// 析构函数
~File() {
cout << "析构文件:" << name << ",大小:" << size << "M" << endl;
}
private:
string name;
double size;
};
int main()
{
string name;
double size;
cin>>name>>size;
File f1(name,size),f2(f1);
return 0;
}
输入样例:
c++学习指南 12.5
输出样例:
创建文件:c++学习指南,大小:12.5M
拷贝生成文件:c++学习指南(1),大小:12.5M
析构文件:c++学习指南(1),大小:12.5M
析构文件:c++学习指南,大小:12.5M
解析:
创建文件:c++学习指南,大小:12.5M
:
- 这是在创建文件对象f1时输出的。
- 在构造函数中,我们传递了文件名name和文件大小size,并在输出语句中将这些值打印出来。
拷贝生成文件:c++学习指南(1),大小:12.5M
:
- 这是在创建文件对象f2时输出的,使用了f1的拷贝构造函数。
- 在拷贝构造函数中,我们将文件名设为f1的文件名加上“(1)”作为后缀,同时保留了文件大小size,然后将这些值打印出来。
析构文件:c++学习指南(1),大小:12.5M
:
- 这是在程序结束时,对象f2被销毁时输出的。
- 在析构函数中,我们输出了对象的文件名和文件大小。
析构文件:c++学习指南,大小:12.5M
:
- 这是在程序结束时,对象f1被销毁时输出的。
- 同样地,在析构函数中,我们输出了对象的文件名和文件大小
为什么f2比f1先被销毁:
在这个程序中,对象f2比对象f1先被销毁的原因是因为它们是按照相反的顺序创建的。
在主函数中,首先创建了f1对象,然后通过拷贝构造函数创建了f2对象。因此,对象f1比对象f2具有更早的创建时间。
按照创建顺序,对象的销毁顺序与其创建顺序相反。因此,当程序结束时,先创建的对象f1会先被销毁,然后才是后创建的对象f2。
这种行为是由C++对象的生命周期管理规则所决定的:对象的销毁顺序与创建顺序相反。