Qt 之 QVector

转载自:http://blog.csdn.net/suer0101/article/details/8561723


QVector类是一个提供动态数组的模板类。

QVector是Qt普通容器类的一种。它将自己的每一个对象存储在连续的内存中,可以使用索引号来快速访问它们。QList、QLinkedList和 QVarLengthArray也提供了相似的功能,它们使用方法如下:

l QList一般用得最多,它能满足我们绝大部分需求。像prepend()和insert()这样的操作通常比QVector要快些,这是由于QList存储它的对象的方式(Algorithmic Complexity)不同。还有它基于索引的API比QLinkedList的基于迭代器的API更方便使用。最后,执行程序时它的代码扩展量更少些。

l QLinkedList,当你需要使用一个真正的链表,要求在恒定的时间内将对象插入到列表的中间,你更想用迭代器而不是索引号来访问对象,这个时候就使用QLinkedList吧!

l QVector,如果你想要在连续的内存上存储你的对象,你的对象比指针还要大,你想避免单独地把对象插入到堆的头部时,使用QVector。

l QVarLengthArray,如果你想要一个低层次的可变大小的容器,QVarLengthArray就足够了,它的优点是速度快!


下面是使用QVector存放整型值和QString的例子:

QVector<int> integerVector;
QVector<QString> stringVector;

QVector保存对象的向量容器,通常是使用初始大小来创建向量容器。举例,下面的代码构造了一个拥有200个元素的QVector:

QVector<QString> vector(200);

如果所创建的向量容器对象没有赋初值,就会被使用这个向量容器的类的默认构造函数进行初始化。基本类型和指针类型都会被初始化为0,如果想使用其它的初值来初始化对象时,可以在初始化时再添加一个参数:

QVector<QString> vector(200,"Pass");

你也可以调用fill()函数在任何时候填充向量容器。
就像C++的数组一样,QVector的索引号也是从0开始的。使用索引号来访问对象时,可以这样operator

if (vector[0] == "Liz")
    vector[0] ="Elizabeth";

如果只是读取向量容器的对象,可以调用at()函数来访问对象:

for (int i = 0; i < vector.size(); ++i)
{
    if (vector.at(i) =="Alfonso")
        cout << "FoundAlfonso at position " << i << endl;
}

调用at()函数来读取对象会比使用operator读取速度更快,因为这不会使用深度复制(deep copy)。

调用data()函数也可以访问保存在QVector的数据。这个函数会返回指向向量容器的第一个对象的指针。这样,你就可以使用指针来访问和修改向量容器内的对象。你可以使用指针将一个QVector向量容器传递给接收普通C++数组的函数。

你可以使用indexOf()和lastIndexOf()来查找某个对象出现的次数。前者从给定的位置向前搜索,后者是向后搜索。如果查找到了它们就返回相应的索引号,否则就返回-1,举例:

int i = vector.indexOf("Harumi");
if (i != -1)
    cout << "Firstoccurrence of Harumi is at position " << i << endl;

contains()函数是用来查找向量容器内是否含有某个对象。

count()函数可以找出某个对象出现的次数。

insert(), replace(), remove(), prepend(), append()可以用来添加,移动和删除某个对象。对于体积较大的向量容器,除了append()和replace()这两个函数外,其它函数会比较慢,因为在内存中移动一个位置时,这些函数会使向量容器内的对象要移动许多次!如果你想要一个能够在中部快速插入和删除的容器时,可以使用QList或者QLinkedList。

resize()函数可以在任何时候改变QVector向量容器的体积。如果新的向量容器体积比以前的要大,QVector也许需要重新分配整个向量容器。QVector会预先分配两倍于实际数据的大小空间,从而减少再分配的次数。

reserve()函数,如果你事先知道向量容器大概包含多少个对象,你可以调用这个函数来预先分配一定的内存大小空间。

capacity()函数会告诉你向量容器所占内存的实际大小空间。

提醒:使用常量运算符和函数时会使QVector进行深度复制,这是隐含共享机制造成的。QVector的值的类型必须是可分配数据类型(assignable data type)。大多数数据类型都是这种类型。但是编译器不会让你存储一个QWidget,但是你可以存储QWidget指针啊!少数函数有额外的要求,比如indexOf()和lastIndexOf()期望值的类型可以支持operator==(),这些特殊要求在相关函数的文档上都有记录。

就像其它容器类一样,QVector支持Jave风格(QVectorIterator和QMutableVectorIterator)和STL风格的迭代器,实际上这些都很少使用,你可以使用索引号啊!

QVector不能插入、添加、替换一个QVector,否则你的应用程序就会报错!

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 在Qt中,可以使用迭代器来遍历QVector容器。 使用QVector的begin()和end()函数来获取迭代器的起始位置和结束位置。 ```cpp QVector<int> vec; vec.append(1); vec.append(2); vec.append(3); vec.append(4); vec.append(5); QVector<int>::const_iterator iter; // 使用const_iterator代替iterator可以防止修改容器元素 for (iter = vec.begin(); iter != vec.end(); ++iter) { int value = *iter; // 通过解引用取得当前元素的值 qDebug() << value; } ``` 使用迭代器,可以从容器的开始位置一直迭代到末尾位置。每次迭代时,将迭代器指向的元素的值取出来使用。 需要注意的是,迭代器是指针的概念,因此可以使用解引用操作符(*)来获取迭代器指向的元素,可以使用自增操作符(++)将迭代器移动到下一个元素。 上述示例代码中的vec是QVector<int>类型的容器,迭代器iter的类型是QVector<int>::const_iterator,由于我们只是读取容器的元素而不修改它们,所以使用const_iterator以避免不必要的拷贝。 通过迭代器,我们可以方便地遍历QVector容器中的元素,并对每个元素进行相应的操作。 ### 回答2: 在Qt中,我们可以使用迭代器来遍历QVector容器。迭代器是指向容器某个元素的对象,通过逐个遍历迭代器,我们可以访问容器中的每个元素。 下面是一个遍历QVector容器的示例代码: ```cpp QVector<int> vector; vector << 1 << 2 << 3 << 4 << 5; // 使用迭代器遍历容器 QVector<int>::iterator it; for (it = vector.begin(); it != vector.end(); ++it) { int element = *it; // 对当前元素进行操作,例如打印输出 qDebug() << element; } ``` 在上面的代码中,我们首先创建了一个QVector容器并添加了一些整数元素。然后,我们使用`vector.begin()`获取容器的起始迭代器,使用`vector.end()`获取容器的结束迭代器。接下来,通过一个for循环,迭代器从起始位置一直遍历到结束位置。在每次迭代中,我们使用`*it`来访问当前迭代器指向的元素,将其赋值给`element`变量进行操作。 这样,我们就可以遍历QVector容器中的每个元素了。当然,你也可以使用其他迭代器函数,如`rbegin()`和`rend()`来逆序遍历容器。 需要注意的是,在遍历QVector容器时,要确保容器中已经有元素,否则容器为空时使用迭代器会导致未定义的行为。 ### 回答3: 遍历 QVector 容器可以通过不同的方法实现。下面是两种常用的方法: 1. 使用迭代器: 通过 QVector 的 begin() 和 end() 函数获取容器的开始和结束迭代器,然后利用循环遍历整个容器,如下所示: ``` QVector<int> numbers = {1, 2, 3, 4, 5}; for (QVector<int>::iterator it = numbers.begin(); it != numbers.end(); ++it) { int number = *it; // 对 number 进行处理 qDebug() << number; } ``` 在循环中,我们使用迭代器 it 来访问容器中的每个元素。通过 *it 可以获取当前迭代器位置的元素。 2. 使用范围循环: C++11 引入了范围循环(Range-based loop)语法,可以更简洁地遍历容器,如下所示: ``` QVector<int> numbers = {1, 2, 3, 4, 5}; for (int number : numbers) { // 对 number 进行处理 qDebug() << number; } ``` 在这个循环中,我们直接将容器 numbers 中的元素赋值给变量 number,无需使用迭代器。 无论使用迭代器还是范围循环,都可以遍历 QVector 容器并对其中的元素进行处理或输出。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值