Главная страница
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.024 c
8-1164005910
sawa
2006-11-20 09:58
2007.09.02
Преобразование mp3 в wma


15-1185970305
max999
2007-08-01 16:11
2007.09.02
как удалить файл?


4-1173028061
GrayFace
2007-03-04 20:07
2007.09.02
Access Violation в shell32.dll при вызове IFolderView.Items


2-1186648638
waif
2007-08-09 12:37
2007.09.02
ADO + access


15-1186130415
исследователь
2007-08-03 12:40
2007.09.02
Непонятная строчка кода