QVector类是提供动态数组的模板类。
QVector是Qt普通容器类的一种。 每个对象都存储在连续的内存中,并且可以使用索引号快速访问。 QList、QLinkedList和QVarLengthArray也具有类似的功能,用于:
Lq列表一般使用最多,可以满足我们的大部分需求。 像prepend (和insert ) )这样的操作通常比QVector快。 这是因为QList“如何保存对象”(Algorithmic Complexity )不同。 此外,基于索引的API比基于QLinkedList迭代器的API更容易使用。 最后,运行程序时的代码扩展量变少。
l QLinkedList,qcdys要求使用真正的链表,即在一定的时间内将对象插入列表的中间。 如果希望迭代器而不是索引号访问对象,请使用QLinkedList。
QVector,如果尝试将对象存储在连续的内存中,对象将大于指针。 如果希望避免单独将对象插入堆的头部,请使用QVector。
l QVarLengthArray,如果你想要低级可变大小的容器,QVarLengthArray就足够了。 具有速度快的优点。
以下是使用QVector存储整数值和QString的示例:
1
q向量积分器;
2
q向量字符串向量器;
QVector存储对象的向量容器,通常使用初始大小创建向量容器。 例如,以下代码构成了具有200个元素的QVector。
qvectorvector(200;
1
如果没有为创建的向量容器对象指定初始值,则由使用此向量容器的类的缺省构造函数初始化。 基本类型和指针类型都初始化为0。 如果希望使用其他初始值初始化对象,可以在初始化时添加参数。
qvectorvector(200,“路径”
1
fill ) )可以随时调用函数来填充向量容器。
就像c的数组一样,QVector的索引号也从0开始。 使用索引号访问对象时,可以这样操作
if(vector[0]==“还是单身的向日葵”
vector[0]=“昏迷甜瓜,数据线”
1
2
如果只是导入向量容器中的对象,则可以调用at )函数来访问对象。
for(intI=0; i vector.size (; I )
{
if(vector.at(I )==“Alfonso”) )。
cout ' foundalfonsoatposition ' iendl;
}
1
2
3
4
5
at ) )调用函数导入对象比使用操作器导入更快,因为不使用“深度复制”(deep copy )。
data ) )函数,还可以访问存储在QVector中的数据。 此函数返回指向向量容器中第一个对象的指针。 这使您可以使用指针访问和修改向量容器中的对象。 可以使用指针将QVector向量容器传递给接收常规c数组的函数。
可以使用indexOf (和lastIndexOf )来确定对象出现的次数。 前者从给定的位置向前检索,后者向后检索。 如果找到,则返回相应的索引号;如果找不到,则返回-1。 示例:
intI=vector.indexof(「Harumi”);
if(I!=-1 )
cout ' firstoccurrenceofharumiisatposition ' iendl;
1
2
3
contains ) )函数用于确定向量容器中是否包含对象。
count ) )函数可以找到一个对象出现的次数。
insert ()、replace ()、remove ()、prepend ()和append () )可用于添加、移动和删除对象。 对于较大的向量容器,除append (和replace )之外的函数较慢。 这是因为在内存中移动位置时,矢量容器中的对象会多次移动。 如果想要可以在中部快速插入和删除的容器,请使用q列表或QLinkedList。
resize ) )函数可以随时改变QVector向量容器的体积。 如果新向量容器的体积大于以前的体积,则QVector可能需要重新指定整个向量容器。 QVector通过提前分配大小是实际数据两倍的空间来减少重新分配的次数。
reserve ) )如果事先知道向量容器包含多少对象,则函数可以调用此函数来预分配一定内存大小的空间。
capacity ) )函数显示向量容器占用的内存的实际大小。
注:使用常量运算符和函数可以深度复制QVector。 这是隐式共享机制造成的。 q矢量的
值的类型必须是可分配数据类型(assignable data type)。大多数数据类型都是这种类型。但是编译器不会让你存储一个QWidget,但是你可以存储QWidget指针啊!少数函数有额外的要求,比如indexOf()和lastIndexOf()期望值的类型可以支持operator==(),这些特殊要求在相关函数的文档上都有记录。就像其它容器类一样,QVector支持Jave风格(QVectorIterator和QMutableVectorIterator)和STL风格的迭代器,实际上这些都很少使用,你可以使用索引号啊!
QVector不能插入、添加、替换一个QVector,否则你的应用程序就会报错!
QT,QVector 基本用法,遍历
QVector,是Qt对所有数组的封装,比如我们想要一个int类型数组,我们原先会写int array[10],我们在Qt里可以写QVector array(10),赋值的时候,我们依然可以照旧array[5]=4;想获取某一项的值也还可以array[9],也就是说,原来的特性我们还可以用。
那么QVector有什么好处呢?
我们可以用count函数获知数组中有多少个元素,方便遍历,原先我们必须预定义好大小,而用QVector我们虽然最好也先定义好大小,但是预先不定义也可以。
我们可以使用append函数或者<<操作符来在数组最后端添加元素而不用担心溢出问题。
需要包含头文件:
#include
添加元素:
QVector strArray;
strArray.append(“Hello”); //可以这样
strArray<<“World!”; //也可以这样
strArray<<“MyName”<<“is”<<“lgdyb”;//也可以这样加上个元素
//现在strArray总共有5个字符串元素,strArray.count()==5
遍历:
QVector::iterator iter;
for (iter=strArray.begin();iter!=strArray.end();iter++)
{
qDebug() << *iter << “ ”;
}
插入:
strArray.insert(1,“这就是在hello和world之间添加”);
删除:
strArray.remove(1); //删除第一个元素,从0开始
strArray.remove(1,3); //从1开始,删除3个元素
复制(取代):
strArray.replace(1,“lgdyb”); //删除第一个元素,从0开始
调用at()函数来读取对象会比使用operator读取速度更快,因为这不会使用深度复制(deep copy)。
调用data()函数也可以访问保存在QVector的数据。这个函数会返回指向向量容器的第一个对象的指针。这样,你就可以使用指针来访问和修改向量容器内的对象。你可以使用指针将一个QVector向量容器传递给接收普通C++数组的函数。
contains()函数是用来查找向量容器内是否含有某个对象。
count()函数可以找出某个对象出现的次数。
resize()函数可以在任何时候改变QVector向量容器的体积。如果新的向量容器体积比以前的要大,QVector也许需要重新分配整个向量容器。QVector会预先分配两倍于实际数据的大小空间,从而减少再分配的次数。
reserve()函数,如果你事先知道向量容器大概包含多少个对象,你可以调用这个函数来预先分配一定的内存大小空间。
capacity()函数会告诉你向量容器所占内存的实际大小空间。