当前位置: 首页 > news >正文

Qt常用容器之:QVector

参考原文:https://www.cnblogs.com/ybqjymy/p/17996789

在计算机编程的世界中,数据结构是一个核心概念,它为我们提供了有效地组织和存储数据的方法。在众多数据结构中,向量(Vector)作为一种动态数组,因其灵活性和高效性受到了广泛的关注。特别是在使用 Qt 框架进行 C++ 编程时,QVector 成为了程序员们的得力工具。

  QVector 是 Qt 容器类库中的一个重要组成部分,它提供了类似于 C++ 标准库中的 std::vector 的功能,但同时拥有 Qt 独特的优势。QVector 是一个动态数组,可以容纳任意数量的元素,支持在末尾添加、插入和删除元素。与其他容器相比,QVector 在随机访问元素时具有出色的性能,同时在尾部添加和删除元素时仍能保持较高的效率。

  在这篇文章中,我们将深入探讨 QVector 的重要性和用法,包括基本操作、性能分析以及与其他容器的对比。我们的目标是帮助读者充分了解 QVector 的优势和局限性,从而在实际项目中做出明智的选择。无论您是 Qt 的新手还是经验丰富的开发者,相信这篇文章都能为您带来一些有用的见解。现在就让我们开始这段探索之旅吧!

QVector的常用接口

  QVector 是 Qt 框架中一个用于存储数据的容器类,它可以存储各种类型的数据,如整数、浮点数、自定义类等。QVector 类提供了多种用于操作数据的接口方法。以下是一些常用接口的详细介绍:

构造函数:

  • QVector():创建一个空的 QVector 容器。
  • QVector(int size):创建一个指定大小的 QVector 容器。
  • QVector(int size, const T &value):创建一个指定大小的 QVector 容器,并用给定值填充。
  • QVector(const QVector<T> &other):复制构造函数,用另一个 QVector 容器创建一个新的 QVector 容器。

元素访问:

  • T &operator[](int i):通过索引访问元素,返回指定索引处的元素的引用。
  • const T &operator[](int i) const:以只读方式通过索引访问元素。
  • T &at(int i):通过索引访问元素,会检查索引是否越界。
  • T &front():返回容器中的第一个元素的引用。
  • const T &front() const:以只读方式返回容器中的第一个元素。
  • T &back():返回容器中的最后一个元素的引用。
  • const T &back() const:以只读方式返回容器中的最后一个元素。

容量和大小:

  • bool isEmpty() const:判断容器是否为空。
  • int size() const:获取容器中元素的数量。
  • int capacity() const:获取容器的容量。
  • void reserve(int size):预分配指定数量的元素空间,提高性能。
  • void squeeze():释放未使用的容量,将容量调整为实际元素数量。

修改容器:

  • void clear():清空容器中的所有元素。
  • void resize(int size):调整容器的大小。
  • void fill(const T &value, int size = -1):用给定值填充容器,可以指定填充个数。
  • void append(const T &value):在容器末尾添加一个元素。
  • void prepend(const T &value):在容器开头添加一个元素。
  • void insert(int i, const T &value):在指定位置插入一个元素。
  • void replace(int i, const T &value):替换指定位置的元素。
  • void remove(int i):移除指定位置的元素。
  • void remove(int i, int count):从指定位置开始移除指定数量的元素。
  • void removeAll(const T &value):移除容器中所有等于给定值的元素。
  • bool removeOne(const T &value):移除容器中第一个等于给定值的元素。

查找:

  • int indexOf(const T &value, int from = 0) const:从指定位置开始查找给定值的元素,返回第一个找到的元素的索引。
  • int lastIndexOf(const T &value, int from = -1) const:从指定位置开始向前查找给定值的元素,返回第一个找到的元素的索引。
  • bool contains(const T &value) const:判断容器中是否包含给定值的元素。
  • int count(const T &value) const:计算容器中给定值的元素的个数。

排序:

  • void sort(Qt::SortOrder order = Qt::AscendingOrder):对容器中的元素进行排序,可以指定升序或降序。
  • void stableSort(Qt::SortOrder order = Qt::AscendingOrder):对容器中的元素进行稳定排序,可以指定升序或降序。

迭代器:

  • iterator begin():返回容器的起始迭代器。
  • const_iterator begin() const:返回容器的只读起始迭代器。
  • iterator end():返回容器的结束迭代器。
  • const_iterator end() const:返回容器的只读结束迭代器。

比较操作符:

  • bool operator==(const QVector<T> &other) const:判断两个 QVector 容器是否相等,元素数量和值都相等时为 true。
  • bool operator!=(const QVector<T> &other) const:判断两个 QVector 容器是否不相等。

其他功能:

  • QVector<T> &operator=(const QVector<T> &other):赋值操作符,将一个 QVector 容器赋值给另一个。
  • QVector<T> mid(int pos, int length = -1) const:获取容器中指定范围的元素,返回一个新的 QVector 容器。
  • void swap(QVector<T> &other):交换两个 QVector 容器的内容。

  以上是 QVector 的常用接口的详细介绍。使用 QVector 时,您可以根据实际需求选择合适的接口进行数据存储和操作。

  下面是一个简单的示例,介绍了 QVector 的一些常用操作:

 1 #include <QVector>2 #include <QDebug>3 4 int main()5 {6     // 创建一个 QVector 容器,并添加元素7     QVector<int> vec;8     vec.append(3);9     vec.append(1);
10     vec.append(4);
11     vec.append(2);
12 
13     qDebug() << "Original QVector:";
14     for (int i = 0; i < vec.size(); ++i) {
15         qDebug() << vec.at(i);
16     }
17 
18     // 使用排序功能
19     vec.sort(Qt::AscendingOrder);
20     qDebug() << "Sorted QVector:";
21     for (int i = 0; i < vec.size(); ++i) {
22         qDebug() << vec.at(i);
23     }
24 
25     // 插入元素
26     vec.insert(1, 8); // 在索引 1 位置插入值 8
27     qDebug() << "QVector after inserting 8 at index 1:";
28     for (int i = 0; i < vec.size(); ++i) {
29         qDebug() << vec.at(i);
30     }
31 
32     // 删除元素
33     vec.remove(2); // 删除索引 2 处的元素
34     qDebug() << "QVector after removing the element at index 2:";
35     for (int i = 0; i < vec.size(); ++i) {
36         qDebug() << vec.at(i);
37     }
38 
39     // 查找元素
40     int index = vec.indexOf(4);
41     if (index != -1) {
42         qDebug() << "Element 4 found at index:" << index;
43     } else {
44         qDebug() << "Element 4 not found";
45     }
46 
47     return 0;
48 }

在这个示例中,我们展示了如何创建 QVector 容器、添加元素、排序、插入元素、删除元素以及查找元素。根据实际需求,您可以使用 QVector 提供的其他接口进行更多操作。

相关文章:

  • 【vue核心技术实战精讲】1.9 Vue指令之v-model双向数据绑定
  • 华为云使用指南02
  • vue 列表渲染
  • k8s 如何获取加入节点命名
  • 浅谈iOS开发中的自动引用计数ARC
  • 使用llamafile 构建本地大模型运用
  • spring boot的返回值里面含有net.sf.json.JSONObject 报错net.sf.json.JSONNull[“empty“])]
  • <深度学习入门学习笔记P1>——《深度学习》
  • 后端返回文件流pdf 下载
  • 【AIGC调研系列】Starling-LM-7B模型与其他模型相比的优势和劣势
  • 更高效稳定 | 基于ACM32 MCU的编程直流电源应用方案
  • C#WPF控件TextBlock详解
  • 通俗易懂:如何通过JVM参数来调整内存大小?
  • OpenFeign原理整理【Java面试】
  • Gitlab CI---could not read username for xxx: no such device or address
  • 345-反转字符串中的元音字母
  • Fundebug计费标准解释:事件数是如何定义的?
  • Linux链接文件
  • opencv python Meanshift 和 Camshift
  • python_bomb----数据类型总结
  • React Native移动开发实战-3-实现页面间的数据传递
  • session共享问题解决方案
  • 工作踩坑系列——https访问遇到“已阻止载入混合活动内容”
  • 配置 PM2 实现代码自动发布
  • 前端面试题总结
  • 智能网联汽车信息安全
  • C# - 为值类型重定义相等性
  • 移动端高清、多屏适配方案
  • $forceUpdate()函数
  • (3)选择元素——(14)接触DOM元素(Accessing DOM elements)
  • (附源码)springboot青少年公共卫生教育平台 毕业设计 643214
  • (收藏)Git和Repo扫盲——如何取得Android源代码
  • (一)appium-desktop定位元素原理
  • (正则)提取页面里的img标签
  • (轉貼)《OOD启思录》:61条面向对象设计的经验原则 (OO)
  • .apk 成为历史!
  • .NET 8 编写 LiteDB vs SQLite 数据库 CRUD 接口性能测试(准备篇)
  • .NET CF命令行调试器MDbg入门(一)
  • .NET Micro Framework初体验
  • .NET 命令行参数包含应用程序路径吗?
  • .NET/C# 将一个命令行参数字符串转换为命令行参数数组 args
  • .Net6支持的操作系统版本(.net8已来,你还在用.netframework4.5吗)
  • .netcore 6.0/7.0项目迁移至.netcore 8.0 注意事项
  • .net中生成excel后调整宽度
  • .php文件都打不开,打不开php文件怎么办
  • .ui文件相关
  • /etc/X11/xorg.conf 文件被误改后进不了图形化界面
  • /usr/bin/python: can't decompress data; zlib not available 的异常处理
  • [ActionScript][AS3]小小笔记
  • [BZOJ 2142]礼物(扩展Lucas定理)
  • [C#C++]类CLASS
  • [C++]priority_queue的介绍及模拟实现
  • [Django开源学习 1]django-vue-admin
  • [GPT]Andrej Karpathy微软Build大会GPT演讲(上)--GPT如何训练
  • [Head First设计模式]策略模式