c – 析构函数查询
发布时间:2020-12-16 03:16:43 所属栏目:百科 来源:网络整理
导读:我有这个下面的程序,我通过引用函数myFunc传递一个向量,在这个函数里面,我向向量添加了一些元素. 我没有释放用new创建对象,现在忽略由此引起的内存泄漏. 在myFunc()执行完成后,我打印变量ctor和dtor 知道构造函数和析构函数被调用了多少次. 输出是: Before
我有这个下面的程序,我通过引用函数myFunc传递一个向量,在这个函数里面,我向向量添加了一些元素.
我没有释放用new创建对象,现在忽略由此引起的内存泄漏. 在myFunc()执行完成后,我打印变量ctor和dtor 输出是: Before Exiting 5 7 我正在创建5个对象,因此ctor是5.但为什么dtor 7?额外的两个计数从何而来?我错过了什么吗? #include #include using namespace std; static int ctor = 0; static int dtor = 0; class MyClass { public: MyClass(int n) { i = n; ctor++; // cout << "Myclass ctor " << ctor << endl; } ~MyClass() { dtor++; // cout << "Myclass dtor" << dtor << endl; } private: int i; }; void myFunc(vector<MyClass> &m); void myFunc(vector<MyClass> &m) { MyClass *mc; for(int i = 0; i < 5; i++) { mc = new MyClass(i); m.push_back(*mc); } } int main() { vector<MyClass> m; vector<MyClass>::iterator it; myFunc(m); cout << "Before Exiting " << ctor << " " << dtor << endl; } 解决方法
向量复制对象,但只有你的int构造函数递增ctor.这不是考虑复制构造的对象,并且因为你没有提供,所以编译器为你提供了它.
加 MyClass(const MyClass& rhs) i(rhs.i) { ++ctor; } 到你的班级,看看是否能平衡计数. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |