1. Заголовок или название темы должно быть информативным !
2. Все тексты фрагментов программ должны помещаться в теги [code] ... [/code] или [code=pas] ... [/code].
3. Прежде чем задавать вопрос, см. "FAQ" и используйте ПОИСК !
4. НЕ используйте форум для личного общения!
5. Самое главное - это раздел теоретический, т.е. никаких задач и программ (за исключением небольших фрагментов) - для этого есть отдельный раздел!
| daZe1 |
Сообщение
#1
|
![]() Новичок ![]() Группа: Пользователи Сообщений: 18 Пол: Мужской Реальное имя: Данил Репутация: 0 |
Кто может обьяснить, почему производительность совершенно одинаковых программ, но использующих разные типы циклов, различается(while - самый "тугодумный", For & repeat побыстрее)??????
|
![]() ![]() |
| КМА |
Сообщение
#2
|
![]() Пионер ![]() ![]() Группа: Пользователи Сообщений: 69 Пол: Мужской Репутация: 3 |
Честно полностью ответ на этот вопрос я не знаю, но могу предположить.
Цикл for ярко выраженный цикл со счетчиком. В ассемблере он будет реализовываться как явный цикл со счетчиком, т. е. @cicl Соответственно после каждого шага переменная cx будет уменьшаться на 1 (и перемещаться на метку @cicl). Это в машинных кодах сделать довольно просто, поэтому и работает быстро. While и Repeat устроены уже немного по другому, в их основе лежит операция сравнения и переход по меткам. Соответственно программе уже необходимо сравнить что-то и уже потом перейти к нужному телу. Отсюда и скорость выполнения будет поменьше (большее число операций, и соответственно большее время на выполнение). Все это, лишь мое предположение. Буду рад если меня кто-то поправит. |
| Malice |
Сообщение
#3
|
![]() Профи ![]() ![]() ![]() ![]() Группа: Пользователи Сообщений: 705 Пол: Мужской Репутация: 20 |
Loop для циклов паскаль не использует, делает просто cmp / jne. Для while и repeat делается практически тоже самое, по-этому скорость должна быть примерно равной. Но на скорость будут влиять такие факторы как тип переменной в условии цикла (для integer будет просто inc i, а для longint-a add [i],1; adc [i+2],0) ну и сложность самого условия (для while и repeat). Плюс не маловажно каким образом изменяется переменная внутри циклов while и repeat, т.к. скорость выполнения inc (i) и I:=i+1 разная.. Это уже как то разбиралось на форуме подробнее.
|
daZe1 производительность разных типов циклов 1.11.2007 17:10
klem4 Улучшение кода 4.11.2007 12:56
daZe1 Malice^Плюс не маловажно каким образом изменяется … 4.12.2007 22:00
Malice
Malice^Плюс не маловажно каким образом изменяется… 4.12.2007 23:48
daZe1 ок!!! спасибо большое за ответ)) :) 11.12.2007 21:44
andriano Оптимизировать сам цикл имеет смысл только в случа… 13.12.2007 2:21
hardcase Оптимизировать сам цикл имеет смысл только в случ… 19.12.2007 6:05
andriano
Но нужно учитывать тот факт, что размер тела цикл… 19.12.2007 12:36
daZe1 да, я слышал про развернутые циклы, но дело в том,… 13.12.2007 5:52
andriano Я так понимаю, что вопрос производительности интер… 13.12.2007 23:36![]() ![]() |
|
Текстовая версия | 24.12.2025 12:46 |