- QWidget *ww=new QWidget;
- qDebug()<<"ww--"<<ww;
- QList<QWidget*>list;
- list.append(ww);
- list.append(new QWidget);
- list.append(new QWidget);
- list.append(new QWidget);
- foreach(QWidget*w,list)
- {
- if(w)
- {
- list.removeOne(w);
- delete w;
- w=NULL;
- qDebug()<<"list size--"<<list.size();
- }
- }
- if(ww)
- {
- qDebug()<<"ww is not null--";
- // qDebug()<<ww;
- }
上面程序输出的结果是
这其中有几个问题在这里说明一下,
1如何清除QList中的数据
首先QList中有多个renmove函数来清除QList中的项,但是如果项是指针,则不会释放指针所指向的内存,如需要则应手动释放。
2释放指针所指向的内存
- foreach(QWidget*w,list)
- {
- if(w)
- {
- list.removeOne(w);
- delete w;
- w=NULL;
- qDebug()<<"list size--"<<list.size();
- }
- }
- if(ww)
- {
- qDebug()<<"ww is not null--";
- // qDebug()<<ww;
- }
但是if(ww)仍然判断为真。
其实,在这里是正确的。这个问题是变量作用域的问题,在循环中,w被delete释放掉了内存,w=NULL;也置为了空,但是并没有对指针ww进行任何修改,
ww所指向的内存地址仍然还是哪个内存地址,只是在循环结束后,这个内存地址所指向的内存所存放的东西已经没有了,所以if(ww)判断为真。
但是qDebug()<<ww;则不能正确打印,因为内容已经不存在了,这不是一个指向正确数据的指针了。
2.
- QList<myClass*> myList
- myClass *obj1 = new myClass;
- myList.append(obj1 );
- //本以为这里就可以释放obj1 的内存了,如果这里释放掉,后面使用 myList.at(obj1的index)会崩溃,因为没有内存。
存放指针类型的时候,append虽然会开辟内存,类也做了拷贝构造函数,但是在手动释放内存的时候会崩溃。
调查发现是不允许释放内存的,需要一次性释放
qDeleteAll(myList);
myList.clear();
做了测试,确实把前面new的内存释放掉了。
具体原因是:打印出来append的内存和obj1的内存一样。进QList的源码发现,append开内存仅仅是用来存放指针的,并不是拷贝。
- QList<myClass*> myList
- myClass *obj1 = new myClass;
- myList.append(obj1 );
- //本以为这里就可以释放obj1 的内存了,如果这里释放掉,后面使用 myList.at(obj1的index)会崩溃,因为没有内存。
存放指针类型的时候,append虽然会开辟内存,类也做了拷贝构造函数,但是在手动释放内存的时候会崩溃。
调查发现是不允许释放内存的,需要一次性释放
qDeleteAll(myList);
myList.clear();
做了测试,确实把前面new的内存释放掉了。
具体原因是:打印出来append的内存和obj1的内存一样。进QList的源码发现,append开内存仅仅是用来存放指针的,并不是拷贝。