介绍
QSequentialIterable
类是一个容器在QVariant
中的可遍历接口。该类允许多种方法来访问存储在QVariant
中容器的元素。如果一个QVariant
可以转换为QVariantList
,那么可以从其中提取出QSequentialIterable
的实例。
QList<int> intList = {7, 11, 42};QVariant variant = QVariant::fromValue(intList);if (variant.canConvert<QVariantList>()) {QSequentialIterable iterable = variant.value<QSequentialIterable>();// Can use foreach:foreach (const QVariant &v, iterable) {qDebug() << v;}// Can use C++11 range-for:for (const QVariant &v : iterable) {qDebug() << v;}// Can use iterators:QSequentialIterable::const_iterator it = iterable.begin();const QSequentialIterable::const_iterator end = iterable.end();for ( ; it != end; ++it) {qDebug() << *it;}}
在迭代容器之前,容器本身不会被复制。
成员函数
-
QSequentialIterable::at(int idx) const
返回容器中位置 idx 处的元素。 -
QSequentialIterable::begin() const
返回容器开头的 QSequentialIterable::const_iterator。这可用于按 STL 风格迭代。 -
QSequentialIterable::canReverseIterate() const
返回是否可以反向迭代容器。这对应于容器的 const_iterator 的 std::bidirectional_iterator_tag 迭代器特征。 -
QSequentialIterable::end() const
返回容器结尾的 QSequentialIterable::const_iterator。这可用于按 STL 风格迭代。 -
QSequentialIterable::size() const
返回容器中的元素数。