Je voudrais obtenir l'horodatage actuel et l'imprimer en utilisant fprintf
.
Pour les systèmes 32 bits:
fprintf(stdout, "%u\n", (unsigned)time(NULL));
Pour les systèmes 64 bits:
fprintf(stdout, "%lu\n", (unsigned long)time(NULL));
Est-ce que jette simplement la valeur retournée par time()
#include <stdio.h>
#include <time.h>
int main(void) {
printf("Timestamp: %d\n",(int)time(NULL));
return 0;
}
ce que tu veux?
$ gcc -Wall -Wextra -pedantic -std=c99 tstamp.c && ./a.out
Timestamp: 1343846167
Pour obtenir des microsecondes depuis l’époque, à partir de C11, la méthode portable consiste à utiliser
int timespec_get(struct timespec *ts, int base)
Malheureusement, C11 n’est pas encore disponible partout. Le portable le plus proche utilise donc l’une des fonctions POSIX clock_gettime
ou gettimeofday
(marqué obsolète dans POSIX.1-2008, qui recommande clock_gettime
).
Le code pour les deux fonctions est presque identique:
#include <stdio.h>
#include <time.h>
#include <stdint.h>
#include <inttypes.h>
int main(void) {
struct timespec tms;
/* The C11 way */
/* if (! timespec_get(&tms, TIME_UTC)) { */
/* POSIX.1-2008 way */
if (clock_gettime(CLOCK_REALTIME,&tms)) {
return -1;
}
/* seconds, multiplied with 1 million */
int64_t micros = tms.tv_sec * 1000000;
/* Add full microseconds */
micros += tms.tv_nsec/1000;
/* round up if necessary */
if (tms.tv_nsec % 1000 >= 500) {
++micros;
}
printf("Microseconds: %"PRId64"\n",micros);
return 0;
}
En deuxième précision, vous pouvez imprimer le champ tv_sec
de la structure timeval
que vous obtenez à partir de gettimeofday()
function. Par exemple:
#include <sys/time.h>
#include <stdio.h>
int main()
{
struct timeval tv;
gettimeofday(&tv, NULL);
printf("Seconds since Jan. 1, 1970: %ld\n", tv.tv_sec);
return 0;
}
Exemple de compilation et d'exécution:
$ gcc -Wall -o test ./test.c
$ ./test
Seconds since Jan. 1, 1970: 1343845834
Notez, cependant, que cela fait un moment depuis Epoch et que long int
est utilisé pour tenir un certain nombre de secondes ces jours-ci.
Il existe également des fonctions permettant d’imprimer des heures lisibles par l’homme. Voir cette page de manuel pour plus de détails. Voici un exemple utilisant ctime()
:
#include <time.h>
#include <stdio.h>
int main()
{
time_t clk = time(NULL);
printf("%s", ctime(&clk));
return 0;
}
Exemple d'exécution et de sortie:
$ gcc -Wall -o test ./test.c
$ ./test
Wed Aug 1 14:43:23 2012
$
#include <stdio.h>
#include <time.h>
int main ()
{
time_t seconds;
seconds = time(NULL);
printf("Seconds since January 1, 1970 = %ld\n", seconds);
return(0);
}
Et vous obtiendrez un résultat similaire:
Secondes depuis le 1er janvier 1970 = 1476107865