Funzione libreria C - clock ()

Descrizione

La funzione di libreria C. clock_t clock(void)restituisce il numero di tick dell'orologio trascorsi dall'avvio del programma. Per ottenere il numero di secondi utilizzati dalla CPU, sarà necessario dividere per CLOCKS_PER_SEC.

Su un sistema a 32 bit in cui CLOCKS_PER_SEC è uguale a 1000000, questa funzione restituirà lo stesso valore ogni 72 minuti circa.

Dichiarazione

Di seguito è riportata la dichiarazione per la funzione clock ().

clock_t clock(void)

Parametri

  • NA

Valore di ritorno

Questa funzione restituisce il numero di tick di clock trascorsi dall'inizio del programma. In caso di errore, la funzione restituisce un valore di -1.

Esempio

L'esempio seguente mostra l'utilizzo della funzione clock ().

#include <time.h>
#include <stdio.h>

int main () {
   clock_t start_t, end_t, total_t;
   int i;

   start_t = clock();
   printf("Starting of the program, start_t = %ld\n", start_t);
    
   printf("Going to scan a big loop, start_t = %ld\n", start_t);
   for(i=0; i< 10000000; i++) {
   }
   end_t = clock();
   printf("End of the big loop, end_t = %ld\n", end_t);
   
   total_t = (double)(end_t - start_t) / CLOCKS_PER_SEC;
   printf("Total time taken by CPU: %f\n", total_t  );
   printf("Exiting of the program...\n");

   return(0);
}

Compiliamo ed eseguiamo il programma sopra che produrrà il seguente risultato:

Starting of the program, start_t = 0
Going to scan a big loop, start_t = 0
End of the big loop, end_t = 20000
Total time taken by CPU: 0.000000
Exiting of the program...