Mesurer une temporisation a l'aide de QueryPerformance
Bonjours
A la suite d'un post sur le Forun Delphi, et les reponses faites par ShaiLeTroll, j'ai teste QueryPerformance, apres recherche sur le Forum C++Builder je n'ai rien trouve, je poste pour l'exemple un code qui est je pense fonctionnel, j'ai un doute sur les testes dans la derniere partie du programme.
Code:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45
|
//---------------------------------------------------------------------------
#include <vcl.h>
#pragma hdrstop
#include "Unit1.h"
//---------------------------------------------------------------------------
#pragma package(smart_init)
#pragma resource "*.dfm"
TForm1 *Form1;
_LARGE_INTEGER BeginTime,EndTime,TickPerSec;
int tempo;
//---------------------------------------------------------------------------
__fastcall TForm1::TForm1(TComponent* Owner)
: TForm(Owner)
{
}
//---------------------------------------------------------------------------
void __fastcall TForm1::Button1Click(TObject *Sender)
{
tempo = 0;
if (!QueryPerformanceFrequency(&TickPerSec)) return;
QueryPerformanceCounter(&BeginTime);
// placer le Delay a tester
// Sleep(100); // millisecondes
// ou
for(int i = 1; i <= 5000000;i++)
{
tempo++;
}
Edit1->Text = tempo;
QueryPerformanceCounter(&EndTime);
double Delay1 = (double)(&EndTime.QuadPart - &BeginTime.QuadPart) / TickPerSec.QuadPart * 1000;
Edit2->Text = Delay1;
double Delay = (double)(&EndTime.QuadPart - &BeginTime.QuadPart) / TickPerSec.QuadPart;
// la je ne suis pas sur des resultats
if (1E-9 < Delay) //if (t <= 1E-9)
Edit3->Text = ("Ghz / ns ") + (FloatToStr(Delay / 1e9));
else if (1E-6 < Delay) //else if (t <= 1E-6)
Edit3->Text = ("Mhz / micro s ") + (FloatToStr(Delay / 1e6));
else if (1E-3 < Delay) //else if (t <= 1E-3)
Edit3->Text = ("Khz / ms ") + (FloatToStr(Delay / 1e3));
else
Edit3->Text = ("Hz / s ") + (FloatToStr(Delay));
}
//--------------------------------------------------------------------------- |