QListWidget的插入删除方法

来源:互联网 发布:php干什么的 编辑:程序博客网 时间:2024/05/29 19:41

以下内容转载自

http://blog.csdn.net/feiyangyangfei/article/details/8524961


已经很久没有写Blog。最近在研究Qt,正好刚刚完成了一个封装了QListWidget的小自定义Widget,中间学习到的一些东西就放在这里分享,这里面复杂(至少对于我这样的初学者很复杂)的迭代器、指针操作,往往让人晕头转向。

我是在ArchLinu x86_64的机器上完成相关代码的,Qt的版本是4.8.0。根据Qt文档,要想从一个QListWidget中获取选中的Item,需要使用selectedItems()成员函数,它的定义如下:

QList<QListWidgetItem *> selectedItems () const

尼玛,长期处理简单小巧的算法程序,极少接触容器模板这种东西的我看完这代码就呆了,这玩意太复杂了,搞了半天才弄明白这应该怎么用。

首先,QList,这是一个Qt实现的双向链表模板。由于这只是一个链表,因此不能随机访问,必须使用迭代器(坑爹啊)。然后是QListWidgetItem的指针。QListWidgetItem是QListWidget存储每一个Item的类,怎么用官方文档已经讲的很明白了,至于指针,有用Qt写过程序的人也肯定能理解为什么。于是,访问它我们需要定义这样一个迭代器:

QList<QListWidgetItem *>::const_iterator i=list.begin();

好,它是一个指针的迭代器,于是我们应当这样访问它的成员变量:

(*i)->text()

好了,这种奇葩的写法我们不看了,还是赶紧切入正题吧。我们需要插入和删除操作,至少需要他们。插入和删除的函数定义分别如下:

void addItem ( const QString & label )
void addItems ( const QStringList & labels )
void addItem ( QListWidgetItem * item ) //我们使用的添加函数
void removeItemWidget ( QListWidgetItem * item ) //删除

可是,如果你直接解引用迭代器当参数扔进去,你会发现很可能你的程序不会正确执行,无论你有多想插入、删除,什么变化都不会看见。看来事情没有那么简单。

在QListWidget中,这个对象自己保存了一个表,用来存所有Item的指针,因为Qt的所有组件都坚守一个观点:任何Qt对象都应当可以动态生成动态销毁。这就意味着两点:一,我们必须复制每个迭代器指向的QListWidgetItem才能把他们插入新的QListWidget;二,只有销毁了我们要删除的Item对象,才算是真正删除这个东西。因此我们的插入删除代码必须改成如下形式:

//插入
QListWidgetItem *newitem=new QListWidgetItem(*(*i));
List->addItem(newitem);
//删除
QListWidgetItem *item = listWidget1->takeItem(r);
RightList->removeItemWidget((*i));
delete (*i);

或许从初学者角度上看,Qt这样的设计过于繁复。但事实证明,这样做不仅安全而且高效(Qt是Copy-on-write)的。而且,这样程序员也能更好地了解一些底层的问题,以方便优化。这也正是C++的特点。从应用上看,Qt的Signal-slot设计、事件处理和强大的跨平台能力是优美而完善的,但从开发上看由于C++的一些问题,它往往让初学者迷惑。看来想学Qt,必须依赖大量的代码练习。






原创粉丝点击