C++ STL学习中遇到的一个问题

#define _CRT_SECURE_NO_WARNINGS
#include
#include
#include
using namespace std;

class Teacher
{
public:
Teacher(string info)
{
this->info = info;
cout << "已经发生了构造" << endl;
}
~Teacher(){
cout << info<< " 已经发生了析构" << endl;
}

private:
string info;
};

int main()
{
vector *vec_Teacher = new vector;
Teacher t1("t1");
Teacher t2("t2");

vec_Teacher->push_back(t1);


vec_Teacher->push_back(t2);//执行到这一句的时候t1已经析构过一次了,析构的原因是因为值传递语义,在函数体内c(push_back)copy了一份

delete vec_Teacher;//问题是为什么这里只发生了一次t2的析构
//在这一步之后不会发生析构,也就是说传入指针的话其实并不会调用析构
system("pause");
return 0;

}

我的问题是,为什么发生了两次t1的析构,一次t2的析构

2个回答

首先遇到这类问题,你应该去看看 vector 的实现代码。这类问题你可以直接断点进去push_back里面看看代码实现。
我大致说一下,你这里出现的问题,无非就是一个:vector要存的大小发生了改变
你可以这么理解,当第一次push_back的时候用了默认的。而第二次push_back的时候,发现vector默认的内存不够了,于是push_back重新删掉以前的内存
(vector的特性是数组,所以要保持内存连续,如果有新增的内存,那么每次新增必须删掉以前的内存,再重新new出新的能容纳新增的内存)。
所以会出现你这个情况,第一次push_back内存够了。第二次push_back内存不够,删掉以前的t1内存(发生t1的析构)。然后再创建一个能容纳ti t2的新内存

上面是解释你push_back。
而delete vec_Teacher;这句会把所有的内存删掉(就是t1 t2 都析构掉)

以上就是解释为什么,会出现俩次t1的析构和一次t2的析构。

在main函数的堆栈上定义的变量,t1 t2会在main函数调用完成才析构。和vec_Teacher是否delete无关。
而main运行完毕,意味着程序的结束,控制台会被断开,所以不是所有的输出都能显示出来,表现为虽然析构了,但是没有对应的输出。
你需要在析构函数内下断点,看停了几次判断调用了几次,而不是看输出。

u012174761
zmn0079 回复Ym影子: 他的意思就是你观察不到堆栈上的对象析构,因为析构的时候主程序已经退出了
2 年多之前 回复
qq_32378713
Ym影子 回复QQ155132206可买实惠C币: 那为什么会在 执行到vec_Teacher->push_back(t2);的时候会调用一次t1的析构
2 年多之前 回复
caozhy
贵阳老马马善福专业维修游泳池堵漏防水工程 回复Ym影子: t1 t2是堆栈上定义的,和vec_Teacher无关啊。
2 年多之前 回复
qq_32378713
Ym影子 谢答,我想问的问题是: 执行到vec_Teacher->push_back(t2);的时候会调用一次t1的析构,而执行到delete vec_Teacher;的时候为什么不会调用t2的析构呢?
2 年多之前 回复
Csdn user default icon
上传中...
上传图片
插入图片
抄袭、复制答案,以达到刷声望分或其他目的的行为,在CSDN问答是严格禁止的,一经发现立刻封号。是时候展现真正的技术了!
立即提问