java风格迭代器:
例如:
QList<T>容器:
只读迭代器类:QListIterator<T>
读写迭代器:QMutableListIterator<T>
QLinkedList<T>容器:
只读迭代器:QLinkedList<T>
读写迭代器:QMutableLinkedList<T>
QVector<T>容器:
只读迭代器:QVectorIterator<T>
读写迭代器:QMutableVectorIterator<T>
实例代码如下:
#include <QCoreApplication>
#include <QDebug> //包含了QList头文件
int main(int argc, char *argv[])
{
QCoreApplication a(argc, argv);
/*
QT的一些类,如QString、QList等,不需要QCoreApplication的支持也能够工作,
但是,在使用Qt编写应用程序时,如果是控制台程序,则建议初始化一个QCoreApplication对象,
Qt5.8创建控制台时自动生成的main.cpp文件默认创建了一个QCoreApplication对象;
如果是GUI图像用户界面程序,则main.cpp则会默认初始化一个QApplication对象
*/
QList<int> list; //创建一个QList<int>栈对象list
list << 1 << 2 << 3 << 4 << 5; //使用操作运算符<<输入数据
QListIterator<int> i(list);
/*
以list为参数初始化一个QListIterator对象i,此时,迭代点处在列表项1的前面,此时并不是只想该列表项
*/
for(; i.hasNext();)
qDebug() << i.next();
/*
hasNext()函数检查迭代点之后是否还有 列表项,如果有,则调用QListIterator<T>::next()函数进行遍历
*/
return a.exec();
}
运行结果如下:
在C++STL中,list容器模板定义在list头文件中,是T类型对象的双向链表。list容器具有一些vector和deque容器所不具备的优势,它可以在常规时间内,在序列已知的任何位置插入和删除元素,也就是说不能索引元素。为了访问list内部的一个元素,必须一个一个地遍历元素,通常从第一个元素或最后一个元素开始遍历。