Qt:QVector
0、说明
template <typename T> class QVector
QVector是存储同一个类型T数据的模板类,其功能是动态数组,数据在其中的存储是一系列连续的存储空间。
QList<T>, QLinkedList<T>, QVector<T>, and QVarLengthArray<T>提供了相似的接口和函数,它们通常可以交叉使用。
QVector和QVarLengthArray都可以接受C类型数组,而QList则不行,当我们用到C API时这点要特别注意。
1、模块和加载项
| Header: | #include <QVector> |
| qmake: | QT += core |
| Inherited By: |
QPolygon, QPolygonF, QStack, QVulkanInfoVector, and QXmlStreamAttributes |
2、构造
| QVector(InputIterator first, InputIterator last) | 用迭代器[first,last)的内容构造QVector |
| QVector(std::initializer_list<T> args) | 用另一个std::initializer_list<T>中的元素构造QVector |
| QVector(QVector<T> other) | 另一个QVector的副本 |
| QVector(int size, T value) | 构造大小为size,元素都是value的QVector |
| QVector(int size) | 构造大小为size的QVector,值都是default-constructed value |
| QVector() |
5、静态方法
| QVector<T> | fromList(QList<T> list) | 从QList构造QVector |
| QVector<T> | fromStdVector(std::vector<T> vector) | 从std::vector<T>构造QVector |
6、实例方法
返回值类型 |
方法 |
说明 |
|
QVector<T> & bool QVector<T> QVector<T> & QVector<T> & QVector<T> & QVector<T> & QVector<T> & bool T |
operator=(QVector<T> other) operator!=(QVector<T> other) operator+(QVector<T> other) operator+=(QVector<T> other) operator+=(T value) operator<<(T value) operator<<(QVector<T> other) operator=(std::initializer_list<T> args) operator==(QVector<T> other) operator[](int i) |
赋值 两个QVector是否相等 在QVector后加另一个QVector构成新的 在QVector后加另一个QVector构成新的 在QVector后加单个Value构成新的 在QVector后加单个Value构成新的 在QVector后加另一个QVector构成新的 用std::initializer_list<T>中的元素构造 可以用v[i]访问索引i的元素 |
| void |
append(T value) append(QVector<T> value) |
在QVector后加另一个QVector构成新的 在QVector后加单个Value构成新的 |
| T | at(int i) | 访问索引i的元素 |
| QVector::const_iterator |
begin() end() erase(QVector::iterator pos) erase(QVector::iterator begin, QVector::iterator end) insert(QVector::iterator before, int count, T value) insert(QVector::iterator before, T value) cbegin() cend() constEnd() |
迭代器 |
| QVector::const_reverse_iterator |
crend() rbegin() rend() |
逆向迭代器 |
| int | capacity() | 该capacity的最大容量(并非实际) |
| void | clear() | 移除所有元素并释放所有容量 |
|
const T * T * |
data() |
把QVector转化为const T * 和 T *,即数组 |
| T | 第一个元素和最后一个元素 | |
| bool | contains(T value) | 是否包含元素value |
| int |
count(T value) count() |
统计元素value的个数 统计元素数 |
| bool |
empty() |
是否为空 |
| bool | endsWith(T value) | 是否以value结尾 |
| QVector<T> & | fill(T value, int size = -1) | 用value填充剩余空间 |
| T |
first() front() |
第一个元素 |
| int |
indexOf(T value, int from = 0) lastIndexOf(T value, int from = -1) |
第一次出现元素value的位置,顺序和倒序 |
| void |
insert(int i, T value) insert(int i, int count, T value) |
往指定位置插入元素 往指定位置插入多个元素 |
| bool | isEmpty() | 是否为空 |
| T | last() | 最后一个元素 |
| int | length() | 元素个数,等同于size()和count() |
| QVector<T> | mid(int pos, int length = -1) | 中间若干个元素构成的QVector |
| void | move(int from, int to) | 把from处的元素移动到to处 |
| void |
pop_back() push_back(T value) push_front(T value) |
移除最后一个元素 移除第一个元素 在末尾插入元素 在开头插入元素 |
| void | prepend(T value) | 在开头插入元素 |
| void |
remove(int i) remove(int i, int count) |
移除指定位置的元素 移除指定位置指定数量的元素 |
| int | removeAll(T t) | 移除所有元素t |
| void | removeAt(int i) | 等同于remove(int i) |
| void | removeFirst() | 移除第一个元素 |
| void | removeLast() | 移除最后一个元素 |
| bool | removeOne(T t) | 移除第一个元素t |
| void | replace(int i, T value) | 替换索引i处的元素为value |
| void | reserve(int size) | 预留size容量 |
| void | resize(int size) | 重设QVector的大小 |
| void | size() | 元素数 |
| void |
squeeze() |
释放所有多余的控件 |
| bool | startsWith(T value) | 是否以指定元素开始 |
| void | swap(QVector<T> &other) | 互换两个QVector的元素 |
| void | swapItemsAt(int i, int j) | 交换QVector位置i和j处的元素 |
| T |
takeAt(int i) takeLast() |
提取并移除指定位置的元素 |
| QList<T> | toList() | 将QVector转换为List |
| std::vector<T> | toStdVector() | 将QVector转换为StdVector |
| T |
value(int i) value(int i, T defaultValue) |
返回位置i处的元素 如果不存在,可以指定默认返回值 和at()、operator[]功能类似 |
Qt:QVector的更多相关文章
- Qt中QVector与QList的应用
首先來看看QVector 的基本使用方式,建立一個可容納兩個元素的QVector ,並使用索引方式存取元素值:QVector<double> vect(2); vect[0] = 1.0; ...
- Qt:QCustomPlot使用教程(二)——基本绘图
0.说明 本节翻译总结自:Qt Plotting Widget QCustomPlot - Basic Plotting 本节内容是使用QCustomPlot进行基本绘图. 本节教程都使用custom ...
- Qt:禁止qDebug的输出
Qt:禁止qDebug的输出 在工程的.pro文件里加上以下编译批令即可: DEFINES += QT_NO_DEBUG_OUTPUT
- Qt:使用自定义的字体
Qt:使用自定义的字体 1. 下载字体文件 2. 加载字体文件 3. 使用字体 QFontDatabase::addApplicationFont("XENOTRON.TTF" ...
- Qt:QJsonObject
0.说明 QJsonObject在逻辑上就是一个Map或Dict!记住这一点对理解它的方法.说明很有帮助. QJsonObject类封装了JSON Object. JSON Object是一个Key- ...
- Qt:QJsonValue
0.说明 QJsonValue类用于操作JSON中的各种数据. JSON是用于存储结构化数据的格式,JSON中的数据可以是六种类型: 基本类型 存储类型 bool QJsonValue::Bool d ...
- Qt:QJsonArray
0.说明 QJsonArray中存储了一系列的QJsonValue.可以向其中插入.删除QJsonValue. 一个QJsonArray可以与QVariantList互相转换.可以通过size()访问 ...
- Qt:QUrl构造时的qrc前缀
参考(按对我帮助从大到小排列): Qt内的各种路径(让人迷惑) - 鬼谷子com - 博客园 qt webengineview 加载本地资源方式 - beautifulday - 博客园 (17条消息 ...
- Qt:QList、QStringList
QList 0.说明 QList<T> 一个QList是存储相同类型一组数据的列表. QStringList是从QList<String>继承而来,并添加了一些好用的方法,如j ...
随机推荐
- 一步一步超级详细的zabbix安装教程
安装说明: 1. 虚拟机上安装两台全新Linux: zabbix-server:192.168.255.128 zabbix-agent :192.168.255.129 2. zabbix-serv ...
- 使用Hot Chocolate和.NET 6构建GraphQL应用(2) —— 实体相关功能实现
系列导航 使用Hot Chocolate和.NET 6构建GraphQL应用文章索引 需求 在本文中,我们将会准备好用于实现GraphQL接口所依赖的底层数据,为下一篇文章具体实现GraphQL接口做 ...
- React 世界的一等公民 - 组件
猪齿鱼Choerodon平台使用 React 作为前端应用框架,对前端的展示做了一定的封装和处理,并配套提供了前端组件库Choerodon UI.结合实际业务情况,不断对组件优化设计,提高代码质量. ...
- Vue.js之计算属性(computed)、属性监听(watch)与方法选项(methods)
vue.js官网:https://cn.vuejs.org/v2/guide/components-registration.html 一.计算属性-computed 1. 作用:能够避免数据冗余,通 ...
- 洛谷 8 月月赛 & 「PMOI」Round · 04
T1 T166167 「PMOI-4」人赢 题目大意 给一个数列的前两项分别为\(n\)和\(m\) 当\(i\geq3\)时\(a_i = a_{i-1}*a_{i-2}\)的个位 给定\(n\), ...
- ApacheCN Golang 译文集 20211025 更新
Go 云原生编程 零.前言 一.现代微服务架构 二.使用 RESTAPI 构建微服务 三.保护微服务 四.使用消息队列的异步微服务架构 五.使用 React 构建前端 六.在容器中部署应用 七.AWS ...
- HowToDoInJava Spring 教程·翻译完成
原文:HowToDoInJava 协议:CC BY-NC-SA 4.0 欢迎任何人参与和完善:一个人可以走的很快,但是一群人却可以走的更远. ApacheCN 学习资源 目录 Spring 5 Spr ...
- bom案例6-轮播图
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 学习JDBC遇到的一些问题
1. 数据库版本与驱动对应问题 参考官方文档:https://dev.mysql.com/doc/connector-j/8.0/en/connector-j-versions.html 具体详情还需 ...
- OSChina 文
转载请注明来源:https://www.cnblogs.com/hookjc/ http://www.oschina.net/p/carbon-forum [高性能PHP论坛 Carbon For ...