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

Вниз

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

 
AlexanderMS ©   (2006-07-05 18:58) [0]

Как мне узнать, как долго выполнялась та или иная процедура? Мне нужно найти самый быстрый способ реализации алгоритма. Как мне узнать это время?


 
StriderMan ©   (2006-07-05 18:59) [1]

логи вести


 
Пусик ©   (2006-07-05 19:13) [2]

function TickCount:Int64;
begin
QueryPerformanceCounter(Result);
end;

function DeltaTickToSeconds(const Delta: Int64):Double;
var
TickFreq: Int64;
begin
QueryPerformanceFrequency(TickFreq);
Result := Delta/TickFreq;
end;

var
 BeginTime: Int64;
 ProcTIme: Int64;
begin
 BeginTime := TickCount;
 <Выполнение процедуры>
 ProcTme := DeltaTickToSeconds(TickCOunt-BeginTime);


см. также GetThreadTimes.


 
Virgo_Style ©   (2006-07-05 19:13) [3]

Now и GetTickCount, например


 
Пусик ©   (2006-07-05 19:26) [4]


> Пусик ©   (05.07.06 19:13) [2]


Прошу прощения. Типы данных не те:

var
 BeginTime: Int64;
 ProcTime: Double;
begin
 BeginTime := TickCount;
 <Выполнение процедуры>
 ProcTme := DeltaTickToSeconds(TickCOunt-BeginTime);


 
koha ©   (2006-07-05 19:28) [5]

Попробуй так:

var
 Form1: TForm1;
 TimeStart,TimeEnd: integer;
implementation

{$R *.dfm}

procedure TForm1.FormCreate(Sender: TObject);
begin
 TimeStart:=GetTickCount();
 sleep(100);
 TimeEnd:=GetTickCount()-TimeStart;
 ShowMessage(IntToStr(TimeEnd));
end;


Время получишь в "милесекондсах".


 
umbra ©   (2006-07-05 19:40) [6]

а какая точность нужна? если низкая, то можно просто в начале функции и в ее конце получать значение функции Now, и по разности этих значений определять прошедшее время



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

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

Наверх




Память: 0.48 MB
Время: 0.049 c
15-1148326662
Pavia
2006-05-22 23:37
2006.07.23
ОС на паскале?


15-1148887793
GM
2006-05-29 11:29
2006.07.23
Геннетичеси модифицированные продукты


4-1144430576
Pojarnik
2006-04-07 21:22
2006.07.23
Ошибка при освобождении dll-ки(пример из Тейксеры и Пачеко)


15-1150810602
Cerberus
2006-06-20 17:36
2006.07.23
Как заблокировать входящий трафик


8-1139224538
Sco
2006-02-06 14:15
2006.07.23
Intel Jpeg Library