【qt】容器的用法

大家好,这里是国中之林!
❥前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家。点击跳转到网站。有兴趣的可以点点进去看看←

一.QVertor

1.应用场景

QVertor的底层实现是数组,所以说它的查询速度贼快
但是插入和删除就非常慢,需要移动大量的数据

因此你需要查询快,同时不怎么插入和删除,那么QVertor你值得拥有

2.增加数据

尾部添加:1.<< 2.append 3.push_back
头部添加: push_front
任意位置添加:insert(位置,数据)

在这里插入图片描述
运行结果:
在这里插入图片描述

3.删除数据

remove(下标号)
removeOne(数据值)
takeAt(下标号)

在这里插入图片描述
运行结果:
在这里插入图片描述

4.修改数据

因为底层是数组,可以通过下标访问进行修改
可以通过replace(下标号,值)修改

在这里插入图片描述
运行结果:
在这里插入图片描述

5.查询数据

可以通过下标直接查询
还可以通过indexOf(数据)获取数据的下标值

在这里插入图片描述
运行结果:
在这里插入图片描述

6.是否包含

contains(数据)

在这里插入图片描述
运行结果:
在这里插入图片描述

7.数据个数

count(数据),括号里面的数据在容器中有几个
count(),该容器总的个数

在这里插入图片描述
运行结果:
在这里插入图片描述

8.交换数据

swapItemsAt(下标号,下标号)

在这里插入图片描述
运行结果:
在这里插入图片描述

9.移动数据

move(下标号,下标号)

在这里插入图片描述
运行结果:
在这里插入图片描述

10.嵌套使用

容器里面再使用一个容器,相当于二维数组

在这里插入图片描述
运行结果:
在这里插入图片描述

二.QList

1.应用场景

QList的底层原理是指针数组,本质上也是一个数组,只不过里面放在指针,指针指向真正的数据。
查询和QVector差不多,但是插入和删除要快一些

所以没做特殊要求时,一般用QList

有了QVector的前车之见,现在就简单了,增删改查的接口基本一样,记住一套用法就足够了。
如果还想知道更多可以在Qt里鼠标放在容器上,按F1进入在线文档查看。

2.QStringList

上节课咱们的字符串分隔符split就是返回的QStringList容器来装分割后的字符串。
QStringList是QList< QString >的子类,其实差不多,只是为了方便。

三.QLinkedList

1.应用场景

QLinkedList的底层实现是双向链表,这样插入和删除的速度就非常快,但是查询慢。

因此需要大量插入和删除的时候,可以用QLinkedList

2.特殊点

  • 因为底层不是数组,所以不能使用下标符进行访问了。
  • 所以说对一些需要下标号位置的接口就不能使用了
    如:remove()不能通过下标的方式,takeAt()等等
  • insert插入只能使用迭代器进行插入

在这里插入图片描述
运行结果:
在这里插入图片描述

3.用迭代器来变量

在这里插入图片描述
运行结果:
在这里插入图片描述
c++里面迭代器你们应该都知道吧。我就不讲了,以后我可能会出c++的教程,但是可能有点久哦,俏皮笑。

四.QStack

1.应用场景

底层实现是栈,是一种特殊的顺序表,先进后出,类似于这样
在这里插入图片描述

2.基本用法

进栈是1,2,3进的
在这里插入图片描述
出是3,2,1出的:
在这里插入图片描述

五.QQueue

1.应用场景

底层的实现机制是队列,这个在现实生活中就非常常见了,就类似于我们生活中的排队。

先来后到,先进先出

2.基本用法

1,2,3的顺序排序进队
在这里插入图片描述
1,2,3的顺序出队列:
在这里插入图片描述

总结:

容器可以理解是一个用来装数据的盒子。
重要的是我们要知道要用什么样的盒子,装什么样的数据。
至于增删改查的用法,知一遍知其二。
所以说应用场景一定要深刻理解。

路漫漫其修远兮,吾将上下而求索。

以下是一些Qt多层容器嵌套的优化示例代码: 1. 使用指针容器 ```c++ // 使用QSharedPointer<MyObject>代替MyObject,避免多次复制数据 QList<QSharedPointer<MyObject>> myList; QSharedPointer<MyObject> obj(new MyObject); myList.append(obj); ``` 2. 减少容器嵌套层数 ```c++ // 使用QHash来替代QList<QPair<...>>,提高查找效率 QHash<QString, int> myHash; myHash.insert("key1", 1); myHash.insert("key2", 2); int value = myHash.value("key1"); ``` 3. 使用迭代器 ```c++ // 使用QListIterator来遍历容器,避免复制容器中的数据 QList<int> myList = {1, 2, 3}; QListIterator<int> iter(myList); while (iter.hasNext()) { int value = iter.next(); qDebug() << value; } ``` 4. 使用预分配的容器大小 ```c++ // 使用QVector::reserve()来预分配容器大小,避免多次重新分配内存 QVector<int> myVector; myVector.reserve(1000); for (int i = 0; i < 1000; i++) { myVector.append(i); } ``` 5. 使用数据流 ```c++ // 使用QFile和QDataStream类来读写数据,避免一次性加载所有数据到内存中 QFile file("data.txt"); if (file.open(QIODevice::ReadOnly)) { QDataStream in(&file); while (!in.atEnd()) { int value; in >> value; qDebug() << value; } } ``` 6. 使用局部变量 ```c++ // 使用局部变量来避免多次访问堆内存,提高访问速度 QList<int> myList = {1, 2, 3}; int sum = 0; for (int i = 0; i < myList.size(); i++) { int value = myList.at(i); sum += value; } qDebug() << sum; ``` 综上所述,这些优化方法可以在Qt多层容器嵌套时提高程序的性能和效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值