QIterator Struct
template <typename Container> struct QIteratorQIterator 是一个模板类,它允许在QVariant 中对容器进行迭代。
头文件: | #include <QIterator> |
CMake: | find_package(Qt6 REQUIRED COMPONENTS Core) target_link_libraries(mytarget PRIVATE Qt6::Core) |
qmake: | QT += core |
自 | Qt 6.0 |
继承: | QBaseIterator |
公共函数
QIterator(QIterable<Container> *iterable, void *iterator) | |
bool | operator!=(const QIterator<Container> &other) const |
QIterator<Container> | operator+(qsizetype j) const |
QIterator<Container> & | operator++() |
QIterator<Container> | operator++(int) |
QIterator<Container> & | operator+=(qsizetype j) |
QIterator<Container> | operator-(qsizetype j) const |
qsizetype | operator-(const QIterator<Container> &j) const |
QIterator<Container> & | operator--() |
QIterator<Container> | operator--(int) |
QIterator<Container> & | operator-=(qsizetype j) |
bool | operator==(const QIterator<Container> &other) const |
相关非成员
QIterator<Container> | operator+(qsizetype j, const QIterator<Container> &k) |
详细描述
QIterator 只能由QIterable 实例创建,其使用方式与其他 stl 类型的迭代器类似。一般来说,QIterator 不应直接使用,而应通过QSequentialIterable 和QAssociativeIterable 提供的派生类来使用。
另请参见 QIterable 。
成员函数文档
[explicit]
QIterator::QIterator(QIterable<Container> *iterable, void *iterator)
用iterable 和指向本地iterator 的指针创建迭代器。
bool QIterator::operator!=(const QIterator<Container> &other) const
如果other 指向与此迭代器不同的项目,则返回true
;否则返回false
。
另请参阅 operator==() 。
QIterator<Container> QIterator::operator+(qsizetype j) const
返回从该迭代器向前j 位置的项目的迭代器。
另请参阅 operator-() 和operator+=()。
QIterator<Container> &QIterator::operator++()
前缀++
操作符 (++it
) 将迭代器前进到容器中的下一个项目,并返回一个指向新的当前项目的迭代器。
在QSequentialIterable::constEnd() 上调用此函数会导致未定义的结果。
另请参阅 operator--()。
QIterator<Container> QIterator::operator++(int)
这是一个重载函数。
后缀++
运算符 (it++
) 将迭代器前进到容器中的下一个项目,并返回一个指向先前当前项目的迭代器。
QIterator<Container> &QIterator::operator+=(qsizetype j)
通过j 项推进迭代器。
另请参阅 operator-=() 和operator+()。
QIterator<Container> QIterator::operator-(qsizetype j) const
返回从该迭代器向后位于j 位置的项目的迭代器。
如果QVariant 中的容器不支持双向迭代,调用此函数将导致未定义的结果。
另请参阅 operator+()、operator-=() 和QIterable::canReverseIterate()。
qsizetype QIterator::operator-(const QIterator<Container> &j) const
这是一个重载函数。
返回两个迭代器之间的距离。
另请参见 operator+()、operator-=() 和QIterable::canReverseIterate()。
QIterator<Container> &QIterator::operator--()
前缀--
操作符 (--it
) 使前一个项目成为当前项目,并返回一个指向新的当前项目的迭代器。
在QSequentialIterable::constBegin() 上调用此函数会导致未定义的结果。
如果QVariant 中的容器不支持双向迭代,调用该函数将导致未定义的结果。
另请参阅 operator++() 和QIterable::canReverseIterate()。
QIterator<Container> QIterator::operator--(int)
这是一个重载函数。
后缀--
运算符 (it--
) 使前一个项目成为当前项目,并返回一个指向前一个当前项目的迭代器。
如果QVariant 中的容器不支持双向迭代,调用此函数将导致未定义的结果。
另请参阅 QIterable::canReverseIterate() 。
QIterator<Container> &QIterator::operator-=(qsizetype j)
使迭代器返回j 项。
如果QVariant 中的容器不支持双向迭代,调用此函数将导致未定义的结果。
另请参阅 operator+=()、operator-() 和QIterable::canReverseIterate()。
bool QIterator::operator==(const QIterator<Container> &other) const
如果other 指向与此迭代器相同的项目,则返回true
;否则返回false
。
另请参阅 operator!=() 。
© 2025 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.