Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2007.09.02;
Скачать: CL | DM;

Вниз

Время просчета пустой процедуры   Найти похожие ветки 

 
lookin ©   (2007-08-08 03:39) [0]

Равно ли оно нулю или очень мало или не очень мало? Или даже если не пустой, что-то типа:

procedure A(entr: string);
begin
 if Pos(" ",entr)=0 then ... else ...;
end;

Ведь во всяком случае проверка на наличие символа " " должна осуществляться... А то сократил существенно вызов таких "пустых" процедур, но полное время просчета значимо не изменилось...


 
Zeqfreed ©   (2007-08-08 08:12) [1]

Пустые процедуры выбрасываются оптимизатором. Непустые, но которые ничего полезного не делают, стоит выбрасывать самому. Чтобы опередить на каком местре программа «застревает», необходимо воспользоваться профилировщиком.

Я вот тут недавно заменил цикл на копирование непосредственно кусков памяти в функции, которая выполнялась согласно профилировщику 80% времени и программа стала выполняться в 20 раз быстрее :)


 
TUser ©   (2007-08-08 09:04) [2]


> функции, которая выполнялась согласно профилировщику 80%
> времени и программа стала выполняться в 20 раз быстрее

Это как?


 
Zeqfreed ©   (2007-08-08 10:34) [3]

> TUser ©   (08.08.07 09:04) [2]

Я же все написал. Если до этого она выполнялась три минуты, то после исправления стала выполняться около десяти секунд.


 
TUser ©   (2007-08-08 10:38) [4]

Если эта процедура занимала 80% времени, то ускорение никак не может быть больше, чем в пять раз.


 
Zeqfreed ©   (2007-08-08 11:09) [5]

> TUser ©   (08.08.07 10:38) [4]

Ну да, в принципе логично :)
Значит перепутал числа. Но прирост в скорости был впечатляющий, тем не менее.


 
lookin ©   (2007-08-08 11:59) [6]

Ну собственно я тоже выкинул, точнее, поправил некоторые процедуры. Что, собственно, я сделал, я поставил в каждую такую процедуру запись в лог-файл, а потом посмотрел, сколько раз у меня выполняются ненужные действия. Сократил ненужные действия раз в 10, ускорение было лишь в несколько сотен миллисекунд, при расчетном времени порядка секунд, десятков секунд...



Страницы: 1 вся ветка

Текущий архив: 2007.09.02;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.019 c
1-1182685511
WebSQLNeederr
2007-06-24 15:45
2007.09.02
Как удалить пустые строки в Мемо


2-1186903598
Debug
2007-08-12 11:26
2007.09.02
Закрытие вкладки TPageControl


2-1186581369
Constantin
2007-08-08 17:56
2007.09.02
Double


15-1186253150
palva
2007-08-04 22:45
2007.09.02
что для программиста - развлечение, то для ламера - смерть


9-1159030536
glscener
2006-09-23 20:55
2007.09.02
[GLScene] Нужна консультация