Главная страница
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.053 c
10-1122560514
alfer
2005-07-28 18:21
2006.07.23
копирование из БД InterBase в Excel с помощью Delphi


2-1151906339
Delphi basic
2006-07-03 09:58
2006.07.23
OpenDialog - укрощение


15-1150867721
Ega23
2006-06-21 09:28
2006.07.23
С Днём рождения! 21 июня


6-1142575428
syst3m_3rror
2006-03-17 09:03
2006.07.23
MAC-адрес


3-1148278150
petvv
2006-05-22 10:09
2006.07.23
Пустые поля после выполнения SQL запроса