-
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;则不能正确打印,因为内容已经不存在了,这不是一个指向正确数据的指针了。
-
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开内存仅仅是用来存放指针的,并不是拷贝。