Главная страница
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.021 c
2-1186551260
alex810
2007-08-08 09:34
2007.09.02
TTable


15-1186039377
VirEx
2007-08-02 11:22
2007.09.02
С днем рождения 29 июля!


2-1186471609
Сергей И
2007-08-07 11:26
2007.09.02
Создание из текстового документа электронной книги


15-1186261619
Kostafey
2007-08-05 01:06
2007.09.02
С днем рождения ! 5 августа


2-1186506722
viktoras
2007-08-07 21:12
2007.09.02
Создание меню