对于
struct whatever
{
int a;
whatever * next;
};
list[whatever * ] A=new list[whatever * ];
list[list [ whatever * ]]B;
A.push_back(...);
A.push_back(...);
B.push_back(A);
(打不出来<>,所以用[]代替了。。。)
来说:这种应该怎么释放内存?
如果delete A;是不是只是把A中存放的指针删掉了,而没有删掉指针指向的内存?
如果
for(auto i=A.begin();i!=A.end();i++)
{
whatever *a=*i;
whatever *p1;
whatever *p2;
p1=p2=a;
while(p2->next!=NULL)
{
p1=p2->parent;
delete p2;
p2=p1;
}
p2=p1=NULL;
}
这样的话是不是把A中的内存和指针都清除了?那B中的指针是会变成野指针么?
因为需要频繁插入和删除,所以必须需要使用list。。。