pthread_getcpuclockid(3) Library Functions Manual pthread_getcpuclockid(3) NOM pthread_getcpuclockid - Recuperer l'identifiant d'horloge de temps CPU d'un thread BIBLIOTHEQUE Bibliotheque de threads POSIX (libpthread, -lpthread) SYNOPSIS #include #include int pthread_getcpuclockid(pthread_t thread, clockid_t *clockid); DESCRIPTION La fonction pthread_getcpuclockid() recupere l'identifiant d'horloge pour l'horloge de temps processeur du thread donne dans thread et le renvoie a l'emplacement vers lequel pointe clockid. VALEUR RENVOYEE En cas de reussite, cette fonction renvoie 0 ; en cas d'erreur, elle renvoie un numero d'erreur non nul. ERREURS ENOENT Les horloges de temps CPU par thread ne sont pas pris en charge par le systeme. ESRCH Aucun fil d'execution avec pour identifiant thread n'a pu etre trouve. ATTRIBUTS Pour une explication des termes utilises dans cette section, consulter attributes(7). +---------------------------------+--------------------------+---------+ |Interface | Attribut | Valeur | +---------------------------------+--------------------------+---------+ |pthread_getcpuclockid() | Securite des threads | MT-Safe | +---------------------------------+--------------------------+---------+ STANDARDS POSIX.1-2008. HISTORIQUE glibc 2.2. POSIX.1-2001. NOTES Quand thread se rapporte au thread appelant, cette fonction renvoie un identifiant qui indique la meme horloge que celle manipulee par clock_gettime(2) et clock_settime(2) avec l'identifiant d'horloge CLOCK_THREAD_CPUTIME_ID. EXEMPLES Le programme ci-dessous cree un thread puis utilise clock_gettime(2) pour recuperer le temps CPU total du processus et le temps CPU utilise par chacun des deux threads. La session suivante montre un exemple d'execution : $ ./a.out Main thread sleeping Subthread starting infinite loop Main thread consuming some CPU time... Process total CPU time: 1.368 Main thread CPU time: 0.376 Subthread CPU time: 0.992 Source du programme /* Lier avec "-lrt" */ #include #include #include #include #include #include #include #include #define handle_error(msg) \e do { perror(msg); exit(EXIT_FAILURE); } while (0) #define handle_error_en(en, msg) \ do { errno = en; perror(msg); exit(EXIT_FAILURE); } while (0) static void * thread_start(void *arg) { printf("Le sous-thread commence une boucle infinie\n"); for (;;) continue; } static void pclock(char *msg, clockid_t cid) { struct timespec ts; printf("%s", msg); if (clock_gettime(cid, &ts) == -1) handle_error("clock_gettime"); printf("%4jd.%03ld\n", (intmax_t) ts.tv_sec, ts.tv_nsec / 1000000); } int main(void) { pthread_t thread; clockid_t cid; int s; s = pthread_create(&thread, NULL, thread_start, NULL); if (s != 0) handle_error_en(s, "pthread_create"); printf("Le thread principal est en sommeil\n"); sleep(1); printf("Le thread principal consomme du temps processeur...\n"); for (unsigned int j = 0; j < 2000000; j++) getppid(); pclock("Temps total du processeur : ", CLOCK_PROCESS_CPUTIME_ID); s = pthread_getcpuclockid(pthread_self(), &cid); if (s != 0) handle_error_en(s, "pthread_getcpuclockid"); pclock("Temps processeur du thread principal : ", cid); /* Les 4 lignes de code precedentes auraient etre pu etre remplacees par : pclock("Temps processeur du thread principal : ", CLOCK_THREAD_CPUTIME_ID); */ s = pthread_getcpuclockid(thread, &cid); if (s != 0) handle_error_en(s, "pthread_getcpuclockid"); pclock("Temps processeur du sous-pthread : 1 ", cid); exit(EXIT_SUCCESS); /* Terminer les deux threads */ } VOIR AUSSI clock_gettime(2), clock_settime(2), timer_create(2), clock_getcpuclockid(3), pthread_self(3), pthreads(7), time(7) TRADUCTION La traduction francaise de cette page de manuel a ete creee par Christophe Blaess , Stephan Rafin , Thierry Vignaud , Francois Micaux, Alain Portal , Jean-Philippe Guerard , Jean-Luc Coulon (f5ibh) , Julien Cristau , Thomas Huriaux , Nicolas Francois , Florentin Duneau , Simon Paillard , Denis Barbier , David Prevot , Frederic Hantrais et Jean- Philippe MENGUAL Cette traduction est une documentation libre ; veuillez vous reporter a la GNU General Public License version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITE LEGALE. Si vous decouvrez un bogue dans la traduction de cette page de manuel, veuillez envoyer un message a . Pages du manuel de Linux 6.06 31 octobre 2023 pthread_getcpuclockid(3)