Главная страница
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.023 c
1-1178203465
kirajax
2007-05-03 18:44
2007.09.02
Объекты в RTF


15-1186077915
KilkennyCat
2007-08-02 22:05
2007.09.02
Вот и заканчивается день ВМФ...


15-1185983624
antonn
2007-08-01 19:53
2007.09.02
потестируйте пожалуйста


2-1186495868
SLesya
2007-08-07 18:11
2007.09.02
dll/bpl + отладчик


15-1186305705
Pasha L
2007-08-05 13:21
2007.09.02
что такое "Относительное изменение функции"? (математика)