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 提供的其他接口进行更多操作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/779119.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HarmonyOS实战开发-使用List组件实现导航与内容联动的效果。

1 卡片介绍 使用ArkTS语言&#xff0c;实现一个导航与内容二级联动的效果。 2 标题 二级联动&#xff08;ArkTS&#xff09; 3 介绍 本篇Codelab是主要介绍了如何基于List组件实现一个导航和内容的二级联动效果。样例主要包含以下功能&#xff1a; 切换左侧导航&#xff…

鸿蒙OS开发实战:【打造自己的搜索入口】

背景 几乎每家应用中都带有搜索功能&#xff0c;关于这个功能的页面不是特别复杂&#xff0c;但如果要追究其背后的一系列逻辑&#xff0c;可能是整个应用中最复杂的一个功能。今天主要实践目标&#xff0c;会抛开复杂的逻辑&#xff0c;尝试纯粹实现一个“搜索主页”&#xf…

初识Node.js与内置模块

能够知道什么是 Node.js能够知道 Node.js 可以做什么能够说出 Node.js 中的 JavaScript 的组成部分能够使用 fs 模块读写操作文件能够使用 path 模块处理路径能够使用 http 模块写一个基本的 web 服务器 一.初识Node.js 1.浏览器中的 JavaScript 的组成部分 2.Node.js 简介 …

MySQL创建表:练习题

练习题&#xff1a; 创建一个名为"students"的数据库&#xff0c;并切换到该数据库。 在"students"数据库中创建一个名为"grades"的表&#xff0c;包含以下字段&#xff1a; id: 整数类型 name: 字符串类型&#xff0c;学生姓名 subject: 字符串…

postgis已有表插入外部表数据带空间字段和主键

1、postgis已有表 其中gid是主键字段,geom是几何字段 2、待插入表的数据(分三种情况) (1)通过坐标将写入几何类型字段 INSERT INTO test (gid, geom, mc,lng,lat) SELECT (SELECT COALESCE(MAX(gid)<

力扣练习3.28

138. 随机链表的复制 浅拷贝和深拷贝&#xff1a; 前者新建一个数据结构&#xff0c;不创建元素副本&#xff1b; 后者不仅新建一个数据结构&#xff0c;而且新建一个数据副本。 深拷贝&#xff08;Deep Copy&#xff09;和浅拷贝&#xff08;Shallow Copy&#xff09;是在复制…

微服务demo(二)nacos服务注册与集中配置

环境&#xff1a;nacos1.3.0 一、服务注册 1、pom&#xff1a; 移步spring官网https://spring.io&#xff0c;查看集成Nacos所需依赖 找到对应版本点击进入查看集成说明 然后再里面找到集成配置样例&#xff0c;这里只截一张&#xff0c;其他集成内容继续向下找 我的&#x…

There is no getter for property named ‘deleted‘

实体类在继承BaseEntity的时候,由于没填写deleted参数名导致mybatis报错 这时候要么改application.yml里的mybatis参数&#x1f447; 要么就将BaseEntity基类的delete上加个existfalse&#x1f447;(推荐)

【ctf.show】--- md5

ctf.show_web9 1.用 dirsearch 扫目录&#xff1a;python dirsearch.py -u 网址 -e php 发现 robots.txt 2.访问 robots.txt 文件 发现 index.phps 3.访问 index.phps 发现源码 <?php $flag""; $password$_POST[password]; if(strlen…

Ventoy装机

文章目录 Ventoy安装操作系统问题U盘无法识别问题BIOS设置图片 Ventoy安装操作系统问题 当前使用的m.2&#xff08;nvm&#xff09;可以使用在台式机上。 "verification failed sercury violation"这个问题似乎与使用Ventoy创建启动盘并在启用了Secure Boot&#x…

被迫走上前端之路第六课之vue的v-for列表渲染

文章目录 语法举个栗子动态显示数组动态显示字典动态显示对象 嵌套实现 有时候我们需要动态显示一些标签重复的内容或者可迭代数据&#xff0c;如果手动一条条实现有点麻烦&#xff0c;而且代码看着不美观&#xff0c;这个时候就要用到v-for来实现 语法 其中&#xff0c;items…

速盾:cdn配置ssl

CDN&#xff08;Content Delivery Network&#xff09;是一种内容分发网络&#xff0c;它的作用是将原始服务器上的内容分发到全球各地的边缘节点上&#xff0c;以提高用户访问速度和稳定性。随着数据传输的安全性要求越来越高&#xff0c;配置SSL&#xff08;Secure Sockets L…

C++——vector类及其模拟实现

前言&#xff1a;前边我们进行的string类的方法及其模拟实现的讲解。这篇文章将继续进行C的另一个常用类——vector。 一.什么是vector vector和string一样&#xff0c;隶属于C中STL标准模板库中的一个自定义数据类型&#xff0c;实际上就是线性表。两者之间有着很多相似&…

从关键词到上下文:GPT 如何重新定义 SEO 策略

如何利用GPT技术革新SEO内容创建&#xff1f; 新的 SEO 格局 探索 SEO 的快速变化&#xff0c;重点关注从以关键字为中心的策略到更深入地了解用户意图和上下文的转变。 GPT 简介及其对内容创建、用户参与和搜索引擎优化 (SEO) 的革命性影响。 了解 GPT&#xff1a;技术范式转…

【数据结构刷题专题】—— 二分查找

二分查找 二分查找模板题&#xff1a;704. 二分查找 二分查找前提&#xff1a; 有序数组数组中无重复元素 左闭右闭&#xff1a; class Solution { public:int search(vector<int>& nums, int target) {int left 0;int right nums.size() - 1;while (left <…

python基础知识3——列表和元组

python基础知识学习笔记之常用数据类型操作 1、列表 1.1、列表的概念和定义 概念&#xff1a;列表是有序的可变的元素集合。 定义&#xff1a; 方式1&#xff1a;[ 元素1, 元素2…] names ["zhangsan", "lisi", "wangwu"] print(names, type…

网络爬虫框架Scrapy的入门使用

Scrapy的入门使用 Scrapy概述引擎&#xff08;Engine&#xff09;调度器&#xff08;Scheduler&#xff09;下载器&#xff08;Downloader&#xff09;SpiderItem Pipeline 基本使用安装scrapy创建项目定义Item数据模型对象创建爬虫(Spider)管道pipeline来保存数据启动爬虫 其他…

消费盲返:新型返利模式引领购物新潮流

消费盲返&#xff0c;一种引领潮流的新型消费返利模式&#xff0c;其核心在于&#xff1a;消费者在平台选购商品后&#xff0c;不仅能享受优惠价格&#xff0c;更有机会获得后续订单的部分利润作为额外奖励。这种创新的返利机制&#xff0c;既提升了消费者的购物体验&#xff0…

AUTOSAR关于内存栈的分层及描述

首先关于关于内存栈的分层&#xff1a;如下图所示&#xff0c;Nvm靠近RTE的&#xff1b;MemIf居中&#xff0c;EA和FEE被包含其中。 其次关于这三层的缩写&#xff1a;可以看到EEPROM的模拟和EEPROM的抽象层。 我们可以看到 大概的数据流&#xff1a; 和大致的结构分层作用&am…

使用argocd作为cd流程

一、前言 讲述关于argocd在cicd流程中的使用&#xff0c;ci这里使用gitlabjenkins流水线的方式&#xff0c;jenkins用于拉代码打包、构建镜像、变更yaml文件的镜像、推送变更的yaml文件到gitlab的gitops仓库中&#xff0c;最后再有argocd实现cd流程&#xff0c; 二、使用 关于…