How to get the current time in milliseconds from C in Linux?

前端 未结 7 875
不知归路
不知归路 2020-11-30 19:09

How do I get the current time on Linux in milliseconds?

相关标签:
7条回答
  • 2020-11-30 19:45

    You have to do something like this:

    struct timeval  tv;
    gettimeofday(&tv, NULL);
    
    double time_in_mill = 
             (tv.tv_sec) * 1000 + (tv.tv_usec) / 1000 ; // convert tv_sec & tv_usec to millisecond
    
    0 讨论(0)
  • 2020-11-30 19:48

    Following is the util function to get current timestamp in milliseconds:

    #include <sys/time.h>
    
    long long current_timestamp() {
        struct timeval te; 
        gettimeofday(&te, NULL); // get current time
        long long milliseconds = te.tv_sec*1000LL + te.tv_usec/1000; // calculate milliseconds
        // printf("milliseconds: %lld\n", milliseconds);
        return milliseconds;
    }
    

    About timezone:

    gettimeofday() support to specify timezone, I use NULL, which ignore the timezone, but you can specify a timezone, if need.


    @Update - timezone

    Since the long representation of time is not relevant to or effected by timezone itself, so setting tz param of gettimeofday() is not necessary, since it won't make any difference.

    And, according to man page of gettimeofday(), the use of the timezone structure is obsolete, thus the tz argument should normally be specified as NULL, for details please check the man page.

    0 讨论(0)
  • 2020-11-30 19:58

    This version need not math library and checked the return value of clock_gettime().

    #include <time.h>
    #include <stdlib.h>
    #include <stdint.h>
    
    /**
     * @return milliseconds
     */
    uint64_t get_now_time() {
      struct timespec spec;
      if (clock_gettime(1, &spec) == -1) { /* 1 is CLOCK_MONOTONIC */
        abort();
      }
    
      return spec.tv_sec * 1000 + spec.tv_nsec / 1e6;
    }
    
    0 讨论(0)
  • 2020-11-30 20:01

    C11 timespec_get

    It returns up to nanoseconds, rounded to the resolution of the implementation.

    It is already implemented in Ubuntu 15.10. API looks the same as the POSIX clock_gettime.

    #include <time.h>
    struct timespec ts;
    timespec_get(&ts, TIME_UTC);
    struct timespec {
        time_t   tv_sec;        /* seconds */
        long     tv_nsec;       /* nanoseconds */
    };
    

    More details here: https://stackoverflow.com/a/36095407/895245

    0 讨论(0)
  • 2020-11-30 20:02

    This can be achieved using the POSIX clock_gettime function.

    In the current version of POSIX, gettimeofday is marked obsolete. This means it may be removed from a future version of the specification. Application writers are encouraged to use the clock_gettime function instead of gettimeofday.

    Here is an example of how to use clock_gettime:

    #define _POSIX_C_SOURCE 200809L
    
    #include <inttypes.h>
    #include <math.h>
    #include <stdio.h>
    #include <time.h>
    
    void print_current_time_with_ms (void)
    {
        long            ms; // Milliseconds
        time_t          s;  // Seconds
        struct timespec spec;
    
        clock_gettime(CLOCK_REALTIME, &spec);
    
        s  = spec.tv_sec;
        ms = round(spec.tv_nsec / 1.0e6); // Convert nanoseconds to milliseconds
        if (ms > 999) {
            s++;
            ms = 0;
        }
    
        printf("Current time: %"PRIdMAX".%03ld seconds since the Epoch\n",
               (intmax_t)s, ms);
    }
    

    If your goal is to measure elapsed time, and your system supports the "monotonic clock" option, then you should consider using CLOCK_MONOTONIC instead of CLOCK_REALTIME.

    0 讨论(0)
  • 2020-11-30 20:04

    Derived from Dan Moulding's POSIX answer, this should work :

    #include <time.h>
    #include <math.h>
    
    long millis(){
        struct timespec _t;
        clock_gettime(CLOCK_REALTIME, &_t);
        return _t.tv_sec*1000 + lround(_t.tv_nsec/1.0e6);
    }
    

    Also as pointed out by David Guyon: compile with -lm

    0 讨论(0)
提交回复
热议问题