Soyez le premier à donner votre avis sur cette source.
Vue 8 231 fois - Téléchargée 390 fois
//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.