class QMap::const_iterator
QMap::const_iterator 类为 QMap 和 QMultiMap 提供 STL 风格的常量迭代器。更多内容...
typedef | iterator_category |
---|---|
const_iterator(const iterator &other) | |
---|---|
const_iterator() | |
const Key & | key() const |
const T & | value() const |
bool | operator!=(const const_iterator &other) const |
const T & | operator*() const |
const_iterator | operator+(int j) const |
const_iterator & | operator++() |
const_iterator | operator++(int) |
const_iterator & | operator+=(int j) |
const_iterator | operator-(int j) const |
const_iterator & | operator--() |
const_iterator | operator--(int) |
const_iterator & | operator-=(int j) |
const T * | operator->() const |
bool | operator==(const const_iterator &other) const |
QMap 同时提供 STL 风格迭代器和 Java 风格迭代器。STL 风格迭代器更底层,使用更笨拙;同时也稍快一些。对于已经了解 STL 的开发者来说更加熟悉。
QMap<Key, T>::const_iterator 用来遍历 QMap(或QMultiMap)。如果想在遍历时修改 QMap,必须使用QMap::iterator。对于非常量 QMap,使用 QMap::const_iterator 通常是好的编程实践,除非需要在遍历时改变 QMap。const 迭代器稍快一些并可以提高代码可读性。
QMap::const_iterator 的默认构造函数创建一个未初始化的迭代器。必须在开始遍历前使用 QMap::constBegin(),QMap::constEnd() 或 QMap::find() 等 QMap 函数初始化它。下面是一个典型的循环,该循环打印出 map 中的所有键值对:
QMap<QString, int> map;
map.insert("January", 1);
map.insert("February", 2);
...
map.insert("December", 12);
QMap<QString, int>::const_iterator i;
for (i = map.constBegin(); i != map.constEnd(); ++i)
cout << i.key() << ": " << i.value() << Qt::endl;
与无序存储元素的 QHash 不同,QMap 通过键的大小有序存储元素。相同键的元素(因为 map 是一个 QMultiMap)将按照从最新到最早插入的顺序连续出现。
同一 map 可以使用多个迭代器。如果向 map 添加元素,已有的迭代器仍然有效。如果从 map 移除元素,指向被移除元素的迭代器会变成悬空迭代器。
**警告:**隐式共享容器迭代器的工作方式和 STL 迭代器不完全相同。当容器的迭代器还处于活动状态时,应该避免拷贝容器。更多信息请参阅隐式共享迭代器问题。
另请参阅 QMap::iterator,QMap::key_iterator 和 QMapIterator.
std::bidirectional_iterator_tag 的别名,表明该迭代器是双向迭代器。
构造一个 other 的副本。
构造一个未初始化的迭代器。
一定不要对未初始化的迭代器调用 key(),value() 和 operator++() 等函数。使用前要用 operator=() 赋值。
另请参阅 QMap::constBegin() 和 QMap::constEnd()。
返回当前元素的键。
另请参阅 value()。
返回当前元素的值。
如果 other 与本迭代器指向的元素不同,返回 true
;否则返回 false
。
另请参阅 operator==()。
返回当前元素的值。
同 value()。
另请参阅 key()。
返回迭代器,指向该迭代器之前 j 个位置的元素。(如果 j 为负,则为之后 j 个位置。)
j 值较大时,该操作会比较慢。
另请参阅 operator-()。
前置 ++ 运算符(++i
)将迭代器向前移动到 map 中的下一个元素并返回指向新位置元素的迭代器。
对 QMap::end() 调用该函数将导致未定义结果。
另请参阅 operator--()。
这是一个重载函数。
后置 ++ 运算符(i++
)将迭代器向前移动到 map 中的下一个元素并返回指向旧位置元素的迭代器。
使迭代器前进 j 个元素。(如果 j 为负,则后退 j 个位置。)
j 值较大时,该操作会比较慢。
另请参阅 operator-=() 和 operator+()。
返回迭代器,指向该迭代器之后 j 个位置的元素。(如果 j 为负,则为之前 j 个位置。)
j 值较大时,该操作会比较慢。
另请参阅 operator+()。
前置 -- 运算符(--i
)使前一个元素成为当前元素并返回指向新位置元素的迭代器。
对 QMap::begin() 调用该函数将导致未定义结果。
另请参阅 operator++()。
这是一个重载函数。
后置 -- 运算符(i--
)使前一个元素成为当前元素并返回指向旧位置元素的迭代器。
使迭代器后退 j 个元素。(如果 j 为负,则前进 j 个位置。)
j 值较大时,该操作会比较慢。
另请参阅 operator+=() 和 operator-()。
返回指向当前元素值的指针。
另请参阅 value()。
如果 other 与本迭代器指向相同的元素,返回 true
;否则返回 false
。
另请参阅 operator!=()。
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Опубликовать ( 0 )