un chtit bout de code pour aider ceux qui cherche un timer très précis. En effet le GetTickCount n'est pas super. Avec ce timer vous pourrez tester des bouts de code qui s'exécutent trop rapidement pour le GetTickCount qui donnent bien souvent 0 ...
voili voilà bonne prog :)
(ds le zip il y a le dsw et dsp en +, pour vous éviter de configurer les settings)
Source / Exemple :
//NE PAS OUBLIER :
// dans Project | Settings | onglet Général,
//choisir "Use MFC in a shared dll"
///////////////////////////////////////////////////
#define VC_EXTRALEAN// Exclude rarely-used stuff from Windows headers (+ rapide à recompiler)
#include <afx.h> //si dans votre projet vous avez #include "stdAfx.h" alors pas la peine d'ajouter ça
#include <winbase.h>//header du compteur haute résolution
#include <iostream> //flux cout, etc ...
using namespace std;//espace de nom...
int main(int argc, char* argv[])
{
int a=0;
cout << "programme de timers" << endl
<< "--------------------" << endl
<< endl;
bool CHR = false;//Compteur Haute Résolution disponible ?
LARGE_INTEGER Compteur1, //un compteur
Compteur2, //un compteur
freq; //le nombre de "tics" en une seconde(dépends de la machine)
if( QueryPerformanceFrequency(&freq) ) //test s'il existe un CHR, si oui enregistre le nbre de "tics" par secondes
CHR = true; //TESTER false, si vous souhaitez utiliser GetTickCount
if(CHR)
cout << "le Compteur Haute R?solution est disponible :)" << endl;//petite phrase pour indication
else
cout << "le Compteur Haute R?solution n'est pas disponible :(" << endl;
if(CHR)
QueryPerformanceCounter(&Compteur1);//on relève le temps au compteur, stocké dans Compteur1
else
Compteur1.QuadPart=GetTickCount(); //au cas ou le CHR ne fonctionne pas
//code dont on veut tester le temps de calcul
//$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
for(int i = 0; i < 10; ++i) //avec une petite boucle for, le GetTickCount rends 0
a +=3; //mais pas le CHR
//for(int i = 0; i < 1000000; ++i)//avec une grande boucle, les résultats sont équivalents
// a+=3;
//$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$$
//fin du code
if(CHR)
QueryPerformanceCounter(&Compteur2);//le calcul est fini on relève le compteur :)
else
Compteur2.QuadPart=GetTickCount(); //idem avec GetTickCount
if(CHR)
{
cout << "temps de calcul en nombre de \"tics\" : ";
cout << static_cast <UINT>(Compteur2.QuadPart - Compteur1.QuadPart) << endl;
cout << "en secondes : "<< static_cast <float>(Compteur2.QuadPart - Compteur1.QuadPart) / static_cast<float>(freq.QuadPart) << endl;
}
else
{
//explications pour getTickCount :
//GetTickCount donne le nombre de tic au moment voulue, mais sa fréquence c'est 1000 tics /seconde = 1 milliseconde
cout << "temps de calcul en millisecondes : ";
cout << static_cast <UINT>(Compteur2.QuadPart - Compteur1.QuadPart) << endl;
cout << "en secondes : "<< static_cast <float>(Compteur2.QuadPart - Compteur1.QuadPart) / 1000;
}
cout << endl << "Presser entr?e ..." << endl;
cin.get();
return 0;
}
Vous n'êtes pas encore membre ?
inscrivez-vous, c'est gratuit et ça prend moins d'une minute !
Les membres obtiennent plus de réponses que les utilisateurs anonymes.
Le fait d'être membre vous permet d'avoir un suivi détaillé de vos demandes et codes sources.
Le fait d'être membre vous permet d'avoir des options supplémentaires.