QList类是一种表示链表的模板类,一种泛型容器类,以列表形态存储并管理其中的列表元素,并支持基于快速索引的数据存取, 也可以进行快速的数据删除操作。
QList类对象表示为一组指向被存储元素的数组,元素个数小于1000的QList类对象能够实现在链表中间的快速插入和查找操作。
此外,由于QList类在链表两端都预先分配了内存,因此实现链表前后端的添加操作都很快(这两个成员函数为prepend ()和append() )。
常见15种构造函数:
1. 初始化
默认时为空链表,可以使用<<操作符添加元素:
2、访问元素
at()执行速度比操作符[ ]更快。
3、插入操作
函数insert(),在指定位置插入值,比如1就是,索引1的值。
4、替换操作
replace()函数可替换指定位置处的值;
5、移除操作
函数removeAt(),移除索引位置的值;
6、移动操作
函数move(int from,int to),将索引from位置的值,移动到索引to位置的值,其他数据向前推。
7、交换操作
swapTtemsAt()函数,交换两个索引对应的值,其它值不变化。
8、尾部插入元素
函数append( )可直接在尾部插入;
void append(const T &value);
9、头部添加元素
函数prepend()可直接首部添加元素
10、移除第一个元素
函数removeFirst()删除列表第一个元素
11、移除最后一个元素
removeLast()删除最后一个元素
12、获取第一个匹配元素对应索引位置
函数indexOf()
13、判断是否包含有相应的元素
函数contains()
14、获取指定值在列表中出现的次数
函数count()
15、获取列表中元素的数量
还是函数count(),此时,无形参;
以下演示,两种回收,qDeleteAll之前已经提及过,这里演示下:
//--- Memory considerations ---
void test_deleteall()
{
QList<Test*> list;
for(int i = 0; i < 5; i++)
{
list.append(new Test()); //Danger no parent
}
qInfo() << "Cleanup";
qDeleteAll(list);
list.clear();
qInfo() << list.length();
}
void test_smart()
{
QList<QSharedPointer<Test>> list;
for(int i = 0; i < 5; i++)
{
QSharedPointer<Test> item(new Test); //Auto memory management
list.append(item);
}
qInfo() << "Remove first";
list.removeFirst();
qInfo() << "Clear";
list.clear();
qInfo() << list.length();
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/96480.html