Russian Qt Forum
Ноябрь 23, 2024, 13:44
Добро пожаловать,
Гость
. Пожалуйста,
войдите
или
зарегистрируйтесь
.
Вам не пришло
письмо с кодом активации?
1 час
1 день
1 неделя
1 месяц
Навсегда
Войти
Начало
Форум
WIKI (Вики)
FAQ
Помощь
Поиск
Войти
Регистрация
Russian Qt Forum
>
Forum
>
Qt
>
Model-View (MV)
>
Эффективность QListIterator?
Страниц: [
1
]
Вниз
« предыдущая тема
следующая тема »
Печать
Автор
Тема: Эффективность QListIterator? (Прочитано 6747 раз)
tguglanaklona
Гость
Эффективность QListIterator?
«
:
Июль 31, 2012, 12:34 »
Насколько QListIterator при переборе списка работает быстрее оператора QList::at ? Скажем, у меня есть перебор списков из всего 6-8 элементов, выполняющийся много раз в цикле. Каждый раз в цикле нужно создавать отдельный QListIterator (списки разные). Либо ничего не создавать и использовать QList::at. Интересует скорость работы.
Записан
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
Re: Эффективность QListIterator?
«
Ответ #1 :
Июль 31, 2012, 12:41 »
Цитата: tguglanaklona от Июль 31, 2012, 12:34
Насколько QListIterator при переборе списка работает быстрее оператора QList::at ? Скажем, у меня есть перебор списков из всего 6-8 элементов, выполняющийся много раз в цикле. Каждый раз в цикле нужно создавать отдельный QListIterator (списки разные). Либо ничего не создавать и использовать QList::at. Интересует скорость работы.
Ничего существенного не выжать, в данном случае лучше пожертвовать "кошкиными слезами" зато писать как удобнее, хоть бы оператором []. Но если человек вообще о производительности думает - это радует, сейчас таких мало.
Записан
tguglanaklona
Гость
Re: Эффективность QListIterator?
«
Ответ #2 :
Июль 31, 2012, 15:55 »
Так вот а будут ли слёзы
? Сколько скажем нужно элементов чтобы стало заметно - никто не проверял это? И не уходит ли лишнего на создание самого объекта QListIterator?
Записан
Kurles
Бывалый
Offline
Сообщений: 480
Re: Эффективность QListIterator?
«
Ответ #3 :
Июль 31, 2012, 15:57 »
Цитата: tguglanaklona от Июль 31, 2012, 15:55
Так вот а будут ли слёзы
? Сколько скажем нужно элементов чтобы стало заметно - никто не проверял это?
Потрать 5 минут, проверь и отпишись )
Записан
Код
C++ (Qt)
while
(
!
asleep
(
)
)
sheep
++;
Swa
Самовар
Offline
Сообщений: 170
Re: Эффективность QListIterator?
«
Ответ #4 :
Июль 31, 2012, 16:03 »
Из справки:
Цитировать
QList is implemented in such a way that direct index-based access is just as fast as using iterators.
Edit
: Если вы создаёте итераторы каждый раз из-за того, что список изменяется, то посмотрите в сторону
QMutableListIterator
«
Последнее редактирование: Июль 31, 2012, 16:06 от Swa
»
Записан
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
Re: Эффективность QListIterator?
«
Ответ #5 :
Июль 31, 2012, 16:23 »
Цитата: Kurles от Июль 31, 2012, 15:57
Цитата: tguglanaklona от Июль 31, 2012, 15:55
Так вот а будут ли слёзы
? Сколько скажем нужно элементов чтобы стало заметно - никто не проверял это?
Потрать 5 минут, проверь и отпишись )
Я тоже с нетерпением жду результатов тестирования
Записан
tguglanaklona
Гость
Re: Эффективность QListIterator?
«
Ответ #6 :
Июль 31, 2012, 17:47 »
Цитата: Swa от Июль 31, 2012, 16:03
Из справки:
Цитировать
QList is implemented in such a way that direct index-based access is just as fast as using iterators.
Edit
: Если вы создаёте итераторы каждый раз из-за того, что список изменяется, то посмотрите в сторону
QMutableListIterator
Спасибо, погляжу)
Записан
tguglanaklona
Гость
Re: Эффективность QListIterator?
«
Ответ #7 :
Июль 31, 2012, 17:49 »
Цитата: Kurles от Июль 31, 2012, 15:57
Цитата: tguglanaklona от Июль 31, 2012, 15:55
Так вот а будут ли слёзы
? Сколько скажем нужно элементов чтобы стало заметно - никто не проверял это?
Потрать 5 минут, проверь и отпишись )
Нееее... пока 5 минут мои заняты
, это вопрос к теории по проблеме
Записан
DmitryM
Гость
Re: Эффективность QListIterator?
«
Ответ #8 :
Июль 31, 2012, 22:12 »
В описание они используют стандартный O(f(n)), так что теоретически одинаково.
Но вся соль в том, что внутри O скрывается константа, которая везде своя.
Поэтому надо делать тесты и замерять какой метод быстрее.
Записан
tguglanaklona
Гость
Re: Эффективность QListIterator?
«
Ответ #9 :
Август 02, 2012, 09:58 »
Цитата: DmitryM от Июль 31, 2012, 22:12
В описание они используют стандартный O(f(n)), так что теоретически одинаково.
Спасибо.
Цитировать
Но вся соль в том, что внутри O скрывается константа, которая везде своя.
Поэтому надо делать тесты и замерять какой метод быстрее.
Ну это скорее от данных зависит, хотя фактически, конечно, при _одинаковом_ наборе данных для тестирования скорость алгоритмов есс-но отлична.
Записан
DmitryM
Гость
Re: Эффективность QListIterator?
«
Ответ #10 :
Август 03, 2012, 10:28 »
Цитата: tguglanaklona от Август 02, 2012, 09:58
Ну это скорее от данных зависит, хотя фактически, конечно, при _одинаковом_ наборе данных для тестирования скорость алгоритмов есс-но отлична.
Константы зависят напрямую от реализации.
Записан
tguglanaklona
Гость
Re: Эффективность QListIterator?
«
Ответ #11 :
Август 09, 2012, 17:08 »
Цитата: DmitryM от Август 03, 2012, 10:28
Цитата: tguglanaklona от Август 02, 2012, 09:58
Ну это скорее от данных зависит, хотя фактически, конечно, при _одинаковом_ наборе данных для тестирования скорость алгоритмов есс-но отлична.
Константы зависят напрямую от реализации.
Ну да, произвольные константы и от реализации зависят, но ей не определяются
Записан
Igors
Джедай : наставник для всех
Offline
Сообщений: 11445
Re: Эффективность QListIterator?
«
Ответ #12 :
Август 09, 2012, 17:34 »
Все эти рассуждения об O(n) "вообще говоря" правильны, но в данном случае неуместны. Основное правило :
- оптимизировать надо место которое является узким (на данный момент), а не то что хочется.
Ну например. Подробностей проекта я конечно не знаю, но рискну предположить что напр QString в нем интенсивно используется. А если так то просто вызов одного конструктора QString обойдется дороже чем удастся сэкономить на 1000 "оптимальных" вызовов итератора. Кому же нужна такая экономия?
Ну и вообще, если хочется пользоваться удобными классами, то о производительности лучше помалкивать. А если кто-то начнет возникать - так приведите ему аргумент типа "скорость разработки" и.т.п.
Записан
Страниц: [
1
]
Вверх
Печать
« предыдущая тема
следующая тема »
Перейти в:
Пожалуйста, выберите назначение:
-----------------------------
Qt
-----------------------------
=> Вопросы новичков
=> Уроки и статьи
=> Установка, сборка, отладка, тестирование
=> Общие вопросы
=> Пользовательский интерфейс (GUI)
=> Qt Quick
=> Model-View (MV)
=> Базы данных
=> Работа с сетью
=> Многопоточное программирование, процессы
=> Мультимедиа
=> 2D и 3D графика
=> OpenGL
=> Печать
=> Интернационализация, локализация
=> QSS
=> XML
=> Qt Script, QtWebKit
=> ActiveX
=> Qt Embedded
=> Дополнительные компоненты
=> Кладовая готовых решений
=> Вклад сообщества в Qt
=> Qt-инструментарий
-----------------------------
Программирование
-----------------------------
=> Общий
=> С/C++
=> Python
=> Алгоритмы
=> Базы данных
=> Разработка игр
-----------------------------
Компиляторы и платформы
-----------------------------
=> Linux
=> Windows
=> Mac OS X
=> Компиляторы
===> Visual C++
-----------------------------
Разное
-----------------------------
=> Новости
===> Новости Qt сообщества
===> Новости IT сферы
=> Говорилка
=> Юмор
=> Объявления
Загружается...