template <typename Key, typename T> class QMutableHashIterator
QMutableHashIterator 类为 QHash 和 QMultiHash 提供 Java 风格的非常量迭代器。更多内容...
头文件: | #include <QMutableHashIterator> |
---|---|
qmake: | QT += core |
QMutableHashIterator(QHash<Key, T> &hash) | |
---|---|
QMutableHashIterator<Key, T> & | operator=(QHash<Key, T> &container) |
bool | findNext(const T &value) |
bool | hasNext() const |
const Key & | key() const |
QMutableHashIterator::Item | next() |
QMutableHashIterator::Item | peekNext() const |
void | remove() |
void | setValue(const T &value) |
void | toBack() |
void | toFront() |
const T & | value() const |
T & | value() |
QHash 同时提供 Java 风格迭代器 和 STL 风格迭代器。Java 风格迭代器比 STL 风格迭代器更高级,更容易使用;同时也略微低效。
QMutableHashIterator<Key, T> 用来遍历并修改 QHash (或 QMultiHash) 。如果不想修改 map(或者 QHash 是 const 的),可以使用更快速的 QHashIterator。
QMutableHashIterator 构造函数接受 QHash 为参数。构造后,迭代器位于哈希表的最开始位置(第一个元素之前)。下面的例子演示如何顺序遍历所有元素:
QHash<int, QWidget *> hash;
...
QMutableHashIterator<QString, QWidget *> i(hash);
while (i.hasNext()) {
i.next();
qDebug() << i.key() << ": " << i.value();
}
next() 函数返回哈希表中的下一个元素并将迭代器前移。key() 和 value() 函数返回跳过的最后一个元素的键和值。
与 STL 风格迭代器不同,Java 风格迭代器指向元素之间而不是直接指向元素。第一次调用 next() 前移迭代器到第一个和第二个元素之间的位置,并返回第一个元素;第二次调用 next() 前移迭代器到第二个和第三个元素之间的位置;以此类推。
如果想查找特定值的所有实例,循环使用 findNext()。例如:
QMutableHashIterator<int, QWidget *> i(hash);
while (i.findNext(widget)) {
qDebug() << "Found widget " << widget << " under key "
<< i.key();
}
如果想在遍历哈希表时移除元素,使用 remove()。如果想修改元素的值,使用 setValue()。
例子:
QMutableHashIterator<QString, QString> i(hash);
while (i.hasNext()) {
i.next();
if (i.key() == i.value())
i.remove();
}
该示例移除所有键和值相等的键值对。
任何时候,对于给定哈希表,只能有一个活动的可修改迭代器。而且,当迭代器处于活动状态时,不可以(不通过迭代器)直接修改哈希表,因为这会使迭代器失效,并导致未定义行为。
另请参阅 QHashIterator 和 QHash::iterator。
从当前迭代器位置开始向前查找值 value。如果找到值为 value 的键值对,返回 true
;否则返回 false
。
调用该函数后,如果找到值 value,迭代器将被移动到匹配元素的后面;否则,迭代器将被移动到容器的末端。
调用遍历函数(next(),findNext())后,该函数返回跳过的最后一个元素的键。
另请参阅 value()。
这是一个重载函数。
返回调用遍历函数后跳过的最后一个元素值的非常量引用。
如果该迭代器后面至少有一个元素,返回 true
,即该迭代器不在容器的末端;否则返回 false
。
另请参阅 next()。
将迭代器移动到容器的末端(最后一个元素之后)。
另请参阅 toFront()。
将迭代器移动到容器的前端(第一个元素之前)。
将迭代器关联到 container 来遍历哈希表。迭代器将被移动到哈希表的前端(第一个元素之前)。
构造一个迭代器来遍历 hash。迭代器将被移动到哈希表的前端(第一个元素之前)。
另请参阅 operator=()。
返回下一个元素并将迭代器向前移动一个位置。
对返回值调用 key() 获取元素的键,调用 value() 获取元素的值。
对位于容器末端的迭代器调用该函数将导致未定义结果。
不移动迭代器而返回下一个元素。
对返回值调用 key() 获取元素的键,调用 value() 获取元素的值。
对位于容器末端的迭代器调用该函数将导致未定义结果。
移除使用遍历函数(next(),findNext())跳过的最后一个元素。
另请参阅 setValue()。
用 value 替换使用遍历函数跳过的最后一个元素的值。
另请参阅 key(),value() 和 remove()。
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Опубликовать ( 0 )