QList释放指针内存

  1. QWidget *ww= new QWidget;
  2. qDebug()<< "ww--"<<ww;
  3. QList<QWidget*> list;
  4. list.append(ww);
  5. list.append( new QWidget);
  6. list.append( new QWidget);
  7. list.append( new QWidget);
  8. foreach(QWidget*w, list)
  9. {
  10. if(w)
  11. {
  12. list.removeOne(w);
  13. delete w;
  14. w= NULL;
  15. qDebug()<< "list size--"<< list.size();
  16. }
  17. }
  18. if(ww)
  19. {
  20. qDebug()<< "ww is not null--";
  21. // qDebug()<<ww;
  22. }

上面程序输出的结果是


这其中有几个问题在这里说明一下,

1如何清除QList中的数据


首先QList中有多个renmove函数来清除QList中的项,但是如果项是指针,则不会释放指针所指向的内存,如需要则应手动释放。

2释放指针所指向的内存

  1. foreach(QWidget*w, list)
  2. {
  3. if(w)
  4. {
  5. list.removeOne(w);
  6. delete w;
  7. w= NULL;
  8. qDebug()<< "list size--"<< list.size();
  9. }
  10. }
  11. if(ww)
  12. {
  13. qDebug()<< "ww is not null--";
  14. // qDebug()<<ww;
  15. }
如果仔细看上面的代码以及代码的输出会发现,虽然循环中已经把QList中的项都清除了,指针也释放掉了,

但是if(ww)仍然判断为真。

其实,在这里是正确的。这个问题是变量作用域的问题,在循环中,w被delete释放掉了内存,w=NULL;也置为了空,但是并没有对指针ww进行任何修改,

ww所指向的内存地址仍然还是哪个内存地址,只是在循环结束后,这个内存地址所指向的内存所存放的东西已经没有了,所以if(ww)判断为真。

但是qDebug()<<ww;则不能正确打印,因为内容已经不存在了,这不是一个指向正确数据的指针了。





  1. QList<myClass*> myList
  2. myClass *obj1 = new myClass;
  3. myList.append(obj1 );
  4. //本以为这里就可以释放obj1 的内存了,如果这里释放掉,后面使用 myList.at(obj1的index)会崩溃,因为没有内存。

存放指针类型的时候,append虽然会开辟内存,类也做了拷贝构造函数,但是在手动释放内存的时候会崩溃。

调查发现是不允许释放内存的,需要一次性释放

qDeleteAll(myList);

myList.clear();

做了测试,确实把前面new的内存释放掉了。

具体原因是:打印出来append的内存和obj1的内存一样。进QList的源码发现,append开内存仅仅是用来存放指针的,并不是拷贝。


  1. QList<myClass*> myList
  2. myClass *obj1 = new myClass;
  3. myList.append(obj1 );
  4. //本以为这里就可以释放obj1 的内存了,如果这里释放掉,后面使用 myList.at(obj1的index)会崩溃,因为没有内存。

存放指针类型的时候,append虽然会开辟内存,类也做了拷贝构造函数,但是在手动释放内存的时候会崩溃。

调查发现是不允许释放内存的,需要一次性释放

qDeleteAll(myList);

myList.clear();

做了测试,确实把前面new的内存释放掉了。



具体原因是:打印出来append的内存和obj1的内存一样。进QList的源码发现,append开内存仅仅是用来存放指针的,并不是拷贝。

猜你喜欢

转载自blog.csdn.net/u014746838/article/details/80933963