vector<自定义类型*>怎样释放才是正确的?
答案:3 悬赏:20 手机版
解决时间 2021-03-01 02:02
- 提问者网友:爱唱彩虹
- 2021-02-28 12:44
如题vector 中存放的是自定义类型的指针,应该怎样释放才是正确的?
最佳答案
- 五星知识达人网友:怀裏藏嬌
- 2021-02-28 12:49
vector提供删除节点的接口 这是VC6下的源码
iterator erase(iterator _P)
{copy(_P + 1, end(), _P);<br> _Destroy(_Last - 1, _Last);<br> --_Last;<br> return (_P); }
void _Destroy(iterator _F, iterator _L)
{for (; _F != _L; ++_F)<br> allocator.destroy(_F); }
你所需要的只是提供删除的接口
即定义自己类型的析构函数就可以了
iterator erase(iterator _P)
{copy(_P + 1, end(), _P);<br> _Destroy(_Last - 1, _Last);<br> --_Last;<br> return (_P); }
void _Destroy(iterator _F, iterator _L)
{for (; _F != _L; ++_F)<br> allocator.destroy(_F); }
你所需要的只是提供删除的接口
即定义自己类型的析构函数就可以了
全部回答
- 1楼网友:鸽屿
- 2021-02-28 15:15
遍历一遍,手动delete掉,别忘记还要erase
- 2楼网友:野慌
- 2021-02-28 14:29
如果是自己new出来的指针,除了用智能指针包装,就只有自己手动delete了
class A;
vector<A*> a;
a.push_back( new A );
a.push_back( new A );
a.push_back( new A );
....
for_each( a.begin(), a.end(), []( A* a ){ delete a; } ); // 释放
或者你可以使用智能指针,比如shared_ptr:
#include <iostream>
#include <vector>
#include <boost\shared_ptr.hpp>
using namespace std;
class A {
public:
~A() { cout << "destructor called.\n"; }
};
int main()
{
{
vector<shared_ptr<A>> a;
for ( int i = 0; i < 10; ++i ) {
a.push_back( shared_ptr<A>( new A ) );
}
}
cin.get();
}
如果你指的是vector中存放指针本身的这部分内存,这个你不用担心,vecotor会自动清理的,如楼上所说。
我要举报
如以上问答信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
大家都在看
推荐资讯