QVector使用详解

QVector使用详解

  • 一、 创建和初始化
    • 1. 默认构造函数
    • 2. 指定大小的构造函数
    • 3. 指定大小和初始值的构造函数
    • 4. 使用 std::initializer_list 初始化
    • 5. 拷贝构造函数
    • 6. 从指针和大小初始化
    • 7. 使用 std::vector 初始化
    • 8. 使用 `QList` 初始化
    • 9. 使用 `QVector` 初始化 `QList`
    • 10. 使用 `fill` 方法初始化
    • 11. 通过 `resize` 方法调整大小并初始化
    • 12. 通过 `reserve` 预留空间
  • 二、元素访问
  • 三、添加和移除元素
  • 四、大小和容量
  • 五、查找和排序
    • 5.1 常规排序
    • 5.2 QVector自定义结构排序
  • 六、其他常用功能
  • 七、`QVector` 和 `std::vector` 的互操作
  • 总结

QVector 是 Qt 框架中提供的一个模板类,用于动态数组的操作。它与标准库中的 std::vector 类似,但更适合在 Qt 应用中使用。 QVector 提供了多种功能,便于管理和操作动态数组。下面将详细介绍 QVector 的各项功能,并给出示例代码。

一、 创建和初始化

可以通过不同的方式创建和初始化 QVector
QVector 是 Qt 框架中提供的一个模板类,用于存储和操作动态数组。下面将详细介绍 QVector 的各种创建和初始化方法,并给出相关的知识点。

1. 默认构造函数

创建一个空的 QVector

QVector<int> vec1;

2. 指定大小的构造函数

创建一个指定大小的 QVector,所有元素都初始化为默认值。

QVector<int> vec2(10); // 创建一个大小为10的QVector,所有元素初始化为0

3. 指定大小和初始值的构造函数

创建一个指定大小并指定初始值的 QVector

QVector<int> vec3(10, 5); // 创建一个大小为10的QVector,所有元素初始化为5

4. 使用 std::initializer_list 初始化

使用初始化列表来创建并初始化 QVector

QVector<int> vec4 = {1, 2, 3, 4, 5};

5. 拷贝构造函数

使用另一个 QVector 初始化。

QVector<int> vec5(vec4); // 使用 vec4 初始化 vec5

6. 从指针和大小初始化

使用指针和大小初始化 QVector

int array[] = {1, 2, 3, 4, 5};
QVector<int> vec6(array, array + 5); // 使用 C++ 数组初始化 QVector

7. 使用 std::vector 初始化

std::vector 转换为 QVector

std::vector<int> stdVec = {1, 2, 3, 4, 5};
QVector<int> vec7 = QVector<int>::fromStdVector(stdVec);

8. 使用 QList 初始化

QList 转换为 QVector

QList<int> list = {1, 2, 3, 4, 5};
QVector<int> vec8 = QVector<int>::fromList(list);

9. 使用 QVector 初始化 QList

QVector 转换为 QList

QVector<int> vec9 = {1, 2, 3, 4, 5};
QList<int> list2 = vec9.toList();

10. 使用 fill 方法初始化

使用 fill 方法将 QVector 中的所有元素设置为指定值。

QVector<int> vec10(10);
vec10.fill(7); // 将所有元素设置为7

11. 通过 resize 方法调整大小并初始化

使用 resize 方法调整 QVector 的大小,新的元素会被默认值初始化。

QVector<int> vec11;
vec11.resize(10); // 调整大小为10,所有新元素初始化为0

12. 通过 reserve 预留空间

预留空间不会改变 QVector 的大小,但会改变它的容量。

QVector<int> vec12;
vec12.reserve(20); // 预留20个元素的空间

二、元素访问

可以通过下标或迭代器访问 QVector 的元素。

#include <QVector>
#include <QDebug>int main() {QVector<int> vec = {1, 2, 3, 4, 5};// 下标访问qDebug() << "First element:" << vec[0];qDebug() << "Second element:" << vec.at(1);// 迭代器访问for (QVector<int>::iterator it = vec.begin(); it != vec.end(); ++it) {qDebug() << *it;}// 常量迭代器访问for (QVector<int>::const_iterator it = vec.cbegin(); it != vec.cend(); ++it) {qDebug() << *it;}return 0;
}

三、添加和移除元素

可以使用多种方法在 QVector 中添加和移除元素。

#include <QVector>
#include <QDebug>int main() {QVector<int> vec;// 添加元素vec.append(1);vec.append(2);vec.append(3);// 在指定位置插入元素vec.insert(1, 10); // 在索引1处插入10// 移除元素vec.remove(2); // 移除索引2处的元素// 移除最后一个元素vec.removeLast();// 输出vec内容for (int value : vec) {qDebug() << value;}return 0;
}

四、大小和容量

可以检查和调整 QVector 的大小和容量。

#include <QVector>
#include <QDebug>int main() {QVector<int> vec = {1, 2, 3, 4, 5};// 获取大小qDebug() << "Size:" << vec.size();// 获取容量qDebug() << "Capacity:" << vec.capacity();// 调整大小vec.resize(10); // 调整大小为10,新增元素初始化为0// 预留容量vec.reserve(20); // 预留容量为20// 缩减容量vec.squeeze(); // 将容量调整为当前大小qDebug() << "New Size:" << vec.size();qDebug() << "New Capacity:" << vec.capacity();return 0;
}

五、查找和排序

5.1 常规排序

可以查找元素和对 QVector 进行排序。

#include <QVector>
#include <QDebug>
#include <algorithm>int main() {QVector<int> vec = {5, 3, 1, 4, 2};// 查找元素int index = vec.indexOf(3); // 查找值为3的元素的索引qDebug() << "Index of 3:" << index;// 排序std::sort(vec.begin(), vec.end());// 输出排序后的vec内容for (int value : vec) {qDebug() << value;}return 0;
}

5.2 QVector自定义结构排序

QVector 中存储自定义结构并对其进行排序,可以利用 qSort 或者 std::sort,需要为自定义结构定义合适的比较函数。下面是一个详细的示例,包括自定义结构的定义、初始化和排序。

  • 步骤:
  1. 定义自定义结构
    创建一个包含两个成员变量的自定义结构。

  2. 实现比较函数
    定义一个比较函数,用于排序。

  3. 创建并初始化 QVector
    创建一个 QVector 对象,并插入一些自定义结构的实例。

  4. 排序 QVector
    使用 std::sortqSortQVector 进行排序。

  • 代码示例:
#include <QCoreApplication>
#include <QVector>
#include <QDebug>
#include <algorithm>// 1. 定义自定义结构
struct Person {QString name;int age;Person(const QString &n, int a) : name(n), age(a) {}
};// 2. 实现比较函数
bool compareByAge(const Person &p1, const Person &p2) {return p1.age < p2.age;
}int main(int argc, char *argv[])
{QCoreApplication a(argc, argv);// 3. 创建并初始化 QVectorQVector<Person> people;people.append(Person("Alice", 30));people.append(Person("Bob", 25));people.append(Person("Charlie", 35));people.append(Person("David", 20));qDebug() << "Before sorting:";for (const Person &p : people) {qDebug() << p.name << p.age;}// 4. 排序 QVectorstd::sort(people.begin(), people.end(), compareByAge);qDebug() << "After sorting by age:";for (const Person &p : people) {qDebug() << p.name << p.age;}return a.exec();
}
  • 解释:
  1. 定义自定义结构

    struct Person {QString name;int age;Person(const QString &n, int a) : name(n), age(a) {}
    };
    

    Person 结构体有两个成员变量 nameage,并通过构造函数进行初始化。

  2. 实现比较函数

    bool compareByAge(const Person &p1, const Person &p2) {return p1.age < p2.age;
    }
    

    比较函数 compareByAge 按照 age 进行比较,用于排序。

  3. 创建并初始化 QVector

    QVector<Person> people;
    people.append(Person("Alice", 30));
    people.append(Person("Bob", 25));
    people.append(Person("Charlie", 35));
    people.append(Person("David", 20));
    

    创建一个 QVector<Person>,并添加一些 Person 对象。

  4. 排序 QVector

    std::sort(people.begin(), people.end(), compareByAge);
    

    使用 std::sort 函数对 QVector 进行排序,传入比较函数 compareByAge

  • 输出结果:
Before sorting:
"Alice" 30
"Bob" 25
"Charlie" 35
"David" 20
After sorting by age:
"David" 20
"Bob" 25
"Alice" 30
"Charlie" 35

通过上述步骤,你可以在 QVector 中存储自定义结构并对其进行排序。根据需要修改比较函数,可以实现基于不同条件的排序。

六、其他常用功能

还有一些其他常用功能,比如 clearcontainscount 等。

#include <QVector>
#include <QDebug>int main() {QVector<int> vec = {1, 2, 3, 4, 5};// 清空QVectorvec.clear();// 检查是否包含某个值vec.append(1);vec.append(2);vec.append(3);bool contains = vec.contains(2);qDebug() << "Contains 2:" << contains;// 获取某个值的出现次数int count = vec.count(2);qDebug() << "Count of 2:" << count;return 0;
}

七、QVectorstd::vector 的互操作

QVectorstd::vector 可以互相转换。

#include <QVector>
#include <vector>
#include <QDebug>int main() {QVector<int> vec = {1, 2, 3, 4, 5};// QVector 转换为 std::vectorstd::vector<int> stdVec = vec.toStdVector();// std::vector 转换为 QVectorQVector<int> newVec = QVector<int>::fromStdVector(stdVec);// 输出 newVec 内容for (int value : newVec) {qDebug() << value;}return 0;
}

总结

QVector 是 Qt 提供的一个功能强大的动态数组类,具备了动态数组所需的各种基本操作,包括添加、删除、访问和遍历元素,同时还提供了大小管理、排序和查找等高级功能。熟练掌握 QVector 可以极大地提高 Qt 开发的效率和代码质量。

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

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

相关文章

力扣2861.最大合金数

力扣2861.最大合金数 对每一台机器都做一次二分答案 class Solution {public:int maxNumberOfAlloys(int n, int k, int budget, vector<vector<int>>& composition, vector<int>& stock, vector<int>& cost) {int res 0;int mx rang…

5款好用的轻量云服务器(618超便宜轻量云)

轻量云服务器是一种面向入门级用户和小型业务的云服务器产品&#xff0c;它们通常价格更实惠&#xff0c;管理起来也相对简单&#xff0c;以下是五款好用的轻量云服务器产品&#xff1a; 1.阿里云 优势&#xff1a;阿里云是国内最大的云服务提供商之一&#xff0c;拥有丰富的配…

二 分 模 板

bool check(int x) {/* ... */} // 检查x是否满足某种性质// 区间[l, r]被划分成[l, mid]和[mid 1, r]时使用&#xff1a; int bsearch_1(int l, int r) {while (l < r){int mid l r >> 1;if (check(mid)) r mid; // check()判断mid是否满足性质else l mid 1…

BT音频方案

一、缩写 缩写 全程 释义 I2S I2S 音频传输接口总线 PCM Pulse-Code Modulation 基础音频数据或翻译为音频接口总线 HFP Handsfree 蓝牙通话协议 A2DP Advanced Audio Distribution Profile 蓝牙媒体音频协议 二、音频流转策略 蓝牙音频功能分为通话声音和媒体…

电脑数字键被锁住不能输入数字

情况: 反复点击数字键盘的NumLock,看它的灯是否能正常启动 1.如果NumLock灯可以正常的打开和关闭,并且无法输入内容 1.1打开控制面板 1.2 进入轻松使用中选择更改键盘的工作方式 1.3找到并点击设置鼠标键 1.4 赵到NumLock设置为关闭,然后确定即可

线性规划问题——单纯形算法

第一步&#xff1a;化“约束标准型” 在每个等式约束中至少有一个变量的系数为正&#xff0c;且这个变量只在该约束中出现。在每个约束方程中选择一个这样的变量称为基本变量。 剩下变量称为非基本变量。 一个简单的栗子 上图是一个约束标准型线性规划的例子。 等式1&#x…

理解查准率P、查全率R及Fβ度量怎么得来的

如果得到的是一组样本在两个算法上的一次预测结果&#xff0c;其中每个样本都被赋予了一个为正样本的概率&#xff08;例如&#xff0c;通过逻辑回归或朴素贝叶斯分类器得到的概率估计&#xff09;&#xff0c;那么可以通过改变不同的阈值点来利用这些预测结果画出PR曲线。 如果…

blender

通用设置: 仅显示/取消隐藏:数字键盘/移动视角:shift+鼠标中键Blender如何给场景添加参考图片-百度经验 (baidu.com)进入编辑模式:Tab编辑模式:点-线-面 反选:ctrl+按键重新计算面朝向:shift+n水密:+修改器:焊接连选的区别: 视窗设置 两个视图 …

Pytorch环境配置的方法

Pytorch虚拟环境配置全流程 以安装pytorch1.9.1为例 1. 创建虚拟环境 安装Anaconda3&#xff0c;打开 PowerShell 创建虚拟环境并进入&#xff1a; conda create -n torch1.9.1 python3.8 conda activate torch1.9.1 conda create -n torch1.9.1 python3.8 conda activate to…

Python - 处理电子书的库

kindleunpack&#xff1a; 转换azw3为epub https://github.com/kevinhendricks/KindleUnpackkindlegen 转换epub为mobiOpenBookPublishers https://github.com/orgs/OpenBookPublishers/repositories?qsort%3Astarsepub2pdf : converting fixed-layout manga/comic files(epub…

实验室中几种电机性能比较与LabVIEW控制介绍

本文从精度、稳定性、速度、负载能力、兼容性等角度对PI闭环步进电机、PI压电陶瓷、Newport SMC100、Newport 8743/8742、Nator x/y/z rotation五种设备进行详细比较&#xff0c;并结合LabVIEW软件开发&#xff0c;提出控制建议&#xff0c;旨在优化电机控制系统&#xff0c;提…

错题记录(小测)

单选 错题1 错题2 错题3 代码题 反转链表 链表的回文结构

【LeetCode】4,寻找两个正序数组中的中位数

题目地址 B站那个官方解答视频实在看不懂&#xff0c;我就根据他那个代码和自己的理解写一篇文章 1. 基本思路 在只有一个有序数组的时候&#xff0c;中位数把数组分割成两个部分。中位数的定义&#xff1a;中位数&#xff0c;又称中点数&#xff0c;中值。中位数是按顺序排列…

消息队列的应用场景有哪些

通常来说&#xff0c;使用消息队列主要能为我们的系统带来下面三点好处&#xff1a; 异步处理 削峰/限流 降低系统耦合性 除了这三点之外&#xff0c;消息队列还有其他的一些应用场景&#xff0c;例如实现分布式事务、顺序保证和数据流处理。 异步处理 通过异步处理提高系…

计算机网络:网络层 - IPv4数据报 ICMP协议

计算机网络&#xff1a;网络层 - IPv4数据报 & ICMP协议 IPv4数据报[版本 : 首部长度 : 区分服务 : 总长度][标识 : 标志 : 片偏移][生存时间 : 协议 : 首部检验和][可变部分 : 填充字段] ICMP协议 IPv4数据报 一个IPv4数据报&#xff0c;由首部和数据两部分组成&#xff…

在Elasticsearch中,过滤器(Filter)是用于数据筛选的一种机制

在Elasticsearch中&#xff0c;过滤器&#xff08;Filter&#xff09;是用于数据筛选的一种机制&#xff0c;它通常用于结构化数据的精确匹配&#xff0c;如数字范围、日期范围、布尔值、前缀匹配等。过滤器不计算相关性评分&#xff0c;因此比查询&#xff08;Query&#xff0…

Python 越来越火爆

Python 越来越火爆 Python 在诞生之初&#xff0c;因为其功能不好&#xff0c;运转功率低&#xff0c;不支持多核&#xff0c;根本没有并发性可言&#xff0c;在计算功能不那么好的年代&#xff0c;一直没有火爆起来&#xff0c;甚至很多人根本不知道有这门语言。 随着时代的…

递归解析 LXML 树并避免重复进入某个节点

1、问题背景 我们在使用 LXML 库解析 MathML 表达式时&#xff0c;可能会遇到这样一个问题&#xff1a;在递归解析过程中&#xff0c;我们可能会重复进入同一个节点&#xff0c;导致解析结果不正确。例如&#xff0c;我们希望将以下 MathML 表达式解析为 Python 表达式&#x…

【数据结构初阶】--- 栈和队列

栈 栈的定义 栈&#xff1a;只允许在一端进行插入或删除的操作 事实上&#xff0c;线性表和链表都可以实现栈&#xff0c;但栈的特点更符合用顺序表实现 顺序表的队尾相当于栈顶&#xff0c;对栈放入数据&#xff0c;相当于顺序表的下标arr[index] x&#xff0c;而栈弹出数…