zion - times
Nom
times - Obtenir les statistiques temporelles du processus.
Résumé
#include <sys/times.h> clock_t times(struct tms * buf );
Description
La fonction times () stocke les durées statistiques du processus en cours dans la structure struct tms pointée par buf . La structure struct tms est définie ainsi dans /usr/include/sys/times.h : .nf struct tms {
clock_t tms_utime; /* durée utilisateur */ clock_t tms_stime; /* durée système */ clock_t tms_cutime; /* durée utilisateur des fils */ clock_t tms_cstime; /* durée système des fils */ |
Le champ tms_utime contient le temps CPU écoulé en exécutant les instructions du processus appelant. Le champ tms_stime contient le temps CPU passé dans les fonctions système exécutées pour le compte du processus appelant. Le champ tms_cutime contient la somme des valeurs de tms_utime et tms_cutime pour tous les processus fils terminés ayant été attendus. Le champ tms_cstime contient la somme des valeurs de tms_stime et tms_cstime pour tous les processus fils terminés ayant été attendus.
Les durées des processus fils terminés (et de leurs descendants) sont ajoutées au moment où wait (2) ou waitpid(2) renvoient leur numéro de PID. En particulier, les durées des petits-fils que le fils n'a pas attendu ne sont jamais vues.
Toutes les durées sont exprimées en ticks d'horloge.
Valeur renvoyée
times renvoie le nombre de tops d'horloge écoulés depuis un instant arbitraire dans le passé. Sous Linux, il s'agit du démarrage du système. Cette valeur peut déborder de l'intervalle contenu dans un clock_t. En cas d'erreur (clock_t) -1 est renvoyé et errno contient le code d'erreur.
Notes
Le nombre de ticks d'horloge par seconde peut être obtenu en consultant
sysconf(_SC_CLK_TCK); |
Sous Linux, si le traitement de SIGCHLD est configuré avec SIG_IGN alors les durées des enfants terminés sont automatiquement incluses dans les champs tms_cstime et tms_cutime , bien que POSIX 1003.1-2001 précise que ceci ne doit se produire que si le processus appelant a fait un wait () pour ses enfants.
Notez que clock (3) renvoie des valeurs de types clock_t qui ne sont pas mesurées en ticks d'horloges mais en CLOCKS_PER_SEC.
Conformité
SVr4, SVID, POSIX, X/OPEN, BSD 4.3
Historique
SVr1-3 renvoit un long et les membres de la structure sont de type time_t bien qu'ils stockent des ticks et pas des secondes depuis le 1er janvier 1970. V7 utilisait des long pour les membres des structures, car il n'avait pas encore de type time_t .
Sur les anciens systèmes, le nombre de ticks d'horloge par seconde est donné par la variable HZ.
Voir aussi
time (1), getrusage (2), wait (2), clock (3), sysconf (3)
Traduction
Christophe Blaess, 1996-2003.
Poster un commentaire