Ym影子 2018-02-18 10:08 采纳率: 100%
浏览 1019
已采纳

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条回答 默认 最新

  • qqabxiaojing 2018-02-19 01:19
    关注

    首先遇到这类问题,你应该去看看 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的析构。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥20 C#调用虚拟键盘TabTip.exe
  • ¥15 Qt4代码实现下面的界面
  • ¥15 CCS离散化传递函数与仿真不一致
  • ¥15 prism提示我reinstall prism 如何解决
  • ¥15 asp.core 权限控制怎么做,需要控制到每个方法
  • ¥20 while循环中OLED显示中断中的数据不正确
  • ¥15 这个视频里的stm32f4代码是怎么写的
  • ¥15 JNA调用DLL报堆栈溢出错误(0xC00000FD)
  • ¥15 请教SGeMs软件的使用
  • ¥15 自己用vb.net编写了一个dll文件,如何只给授权的用户使用这个dll文件进行打包编译,未授权用户不能进行打包编译操作?