![]() |
Здравствуйте, гость ( Вход | Регистрация )
![]() ![]() |
![]() |
Litkevich Yuriy |
![]()
Сообщение
#11
|
![]() разработчик РЭА ![]() ![]() ![]() ![]() ![]() ![]() ![]() Группа: Сомодератор Сообщений: 9669 Регистрация: 9.1.2008 Из: Тюмень Пользователь №: 64 Спасибо сказали: 807 раз(а) Репутация: ![]() ![]() ![]() |
Qt предоставляет два типа итераторов
|
|
|
rnd |
![]()
Сообщение
#12
|
Студент ![]() Группа: Участник Сообщений: 54 Регистрация: 22.7.2009 Пользователь №: 930 Спасибо сказали: 1 раз(а) Репутация: ![]() ![]() ![]() |
Нужно помнить, что map (QMap) сортирует элементы по ключу, именно поэтому к ключу предъявляется требование less-then comparable(т.е. определена операция <).
Поэтому при обычном переборе он и будет отдавать элементы в порядке возрастания ключей. А как он устроен внутри - дело второе. Если порядок элементов не важен (или для ключа недоступна операция <) - можно пользоваться QHash to SABROG, все-таки итераторы гораздо более универсальны, чем индексы. Индексы - это по сути только последовательные контейнеры, которые предоставляют произвольный доступ (vector, deque, в Qt QList). А вот когда существует не один вариант обхода контейнера - итераторы рулят, например дерево: post_order_iterator - узел после детей pre_order_iterator - узел перед детьми breadth_first_iterator - все узлы по уровням и т.п. Кстати, rbegin(), rend() - простейшие примеры нестандартного обхода |
|
|
![]() ![]() ![]() |
![]() |
|
Текстовая версия | Сейчас: 12.3.2025, 19:55 |