zoukankan      html  css  js  c++  java
  • linux高精度struct timespec 和 struct timeval

    一、struct timespec 定义:

    typedef long time_t;
    #ifndef _TIMESPEC
    #define _TIMESPEC
    struct timespec {
    time_t tv_sec; // seconds 
    long tv_nsec; // and nanoseconds 
    };
    #endif
    struct timespec有两个成员,一个是秒,一个是纳秒, 所以最高精确度是纳秒。
    一般由函数int clock_gettime(clockid_t, struct timespec *)获取特定时钟的时间,常用如下4种时钟:
    CLOCK_REALTIME 统当前时间,从1970年1.1日算起
    CLOCK_MONOTONIC 系统的启动时间,不能被设置
    CLOCK_PROCESS_CPUTIME_ID 本进程运行时间
    CLOCK_THREAD_CPUTIME_ID 本线程运行时间
    struct tm *localtime(const time_t *clock);  //线程不安全
    struct tm* localtime_r( const time_t* timer, struct tm* result );//线程安全
    size_t strftime (char* ptr, size_t maxsize, const char* format,const struct tm* timeptr );

    二、struct timeval 定义:

    struct timeval {
    time_t tv_sec; // seconds 
    long tv_usec; // microseconds 
    };
    struct timezone{ 
    int tz_minuteswest; //miniutes west of Greenwich 
    int tz_dsttime; //type of DST correction 
    };

    struct timeval有两个成员,一个是秒,一个是微秒, 所以最高精确度是微秒。
    一般由函数int gettimeofday(struct timeval *tv, struct timezone *tz)获取系统的时间 


     1 #include<stdio.h>
     2 #include<time.h>
     3 #include<sys/time.h>
     4 
     5 void nowtime_ns()
     6 {
     7     printf("---------------------------struct timespec---------------------------------------
    "); 
     8     printf("[time(NULL)]     :     %ld
    ", time(NULL)); 
     9     struct timespec ts;
    10     clock_gettime(CLOCK_REALTIME, &ts);
    11     printf("clock_gettime : tv_sec=%ld, tv_nsec=%ld
    ", ts.tv_sec, ts.tv_nsec);
    12     
    13     struct tm t;
    14     char date_time[64];
    15     strftime(date_time, sizeof(date_time), "%Y-%m-%d %H:%M:%S", localtime_r(&ts.tv_sec, &t));
    16     printf("clock_gettime : date_time=%s, tv_nsec=%ld
    ", date_time, ts.tv_nsec);
    17 }
    18 void nowtime_us()
    19 {
    20     printf("---------------------------struct timeval----------------------------------------
    "); 
    21     printf("[time(NULL)]    :    %ld
    ", time(NULL)); 
    22     struct timeval us;
    23     gettimeofday(&us,NULL);
    24     printf("gettimeofday: tv_sec=%ld, tv_usec=%ld
    ", us.tv_sec, us.tv_usec);
    25     
    26     struct tm t;
    27     char date_time[64];
    28     strftime(date_time, sizeof(date_time), "%Y-%m-%d %H:%M:%S", localtime_r(&us.tv_sec, &t));
    29     printf("gettimeofday: date_time=%s, tv_usec=%ld
    ", date_time, us.tv_usec);
    30 }
    31 
    32 int main(int argc, char* argv[])
    33 {
    34     nowtime_ns();
    35     printf("
    ");
    36     nowtime_us();
    37     printf("
    ");
    38     return 0;
    39 }

     1 #include <time.h>
     2 
     3 // 返回自系统开机以来的毫秒数(tick)
     4 unsigned long GetTickCount()
     5 {
     6     struct timespec ts;
     7 
     8     clock_gettime(CLOCK_MONOTONIC, &ts);
     9 
    10     return (ts.tv_sec * 1000 + ts.tv_nsec / 1000000);
    11 }
    12 
    13 
    14 int main()
    15 {
    16     struct timespec time1 = { 0, 0 };
    17 
    18     clock_gettime(CLOCK_REALTIME, &time1);
    19     printf("CLOCK_REALTIME: %d, %d
    ", time1.tv_sec, time1.tv_nsec);
    20 
    21     clock_gettime(CLOCK_MONOTONIC, &time1);
    22     printf("CLOCK_MONOTONIC: %d, %d
    ", time1.tv_sec, time1.tv_nsec);
    23 
    24     clock_gettime(CLOCK_MONOTONIC_RAW, &time1);
    25     printf("CLOCK_MONOTONIC_RAW: %d, %d
    ", time1.tv_sec, time1.tv_nsec);
    26 
    27     clock_gettime(CLOCK_PROCESS_CPUTIME_ID, &time1);
    28     printf("CLOCK_PROCESS_CPUTIME_ID: %d, %d
    ", time1.tv_sec,
    29            time1.tv_nsec);
    30 
    31     clock_gettime(CLOCK_THREAD_CPUTIME_ID, &time1);
    32     printf("CLOCK_THREAD_CPUTIME_ID: %d, %d
    ", time1.tv_sec,
    33            time1.tv_nsec);
    34 
    35     printf("
    %d
    ", time(NULL));
    36 
    37     printf("tick count in ms: %ul
    ", GetTickCount());
    38 
    39     return 0;
    40 }
  • 相关阅读:
    2-6 求阶乘序列前N项和
    2-5 求平方根序列前N项和
    2-4 求交错序列前N项和
    2-3 求平方与倒数序列的部分和
    2-2 阶梯电价
    2-1 求整数均值
    2-17 生成3的乘方表
    【秋招之行】自白篇
    Django开发个人博客入门学习经验贴
    浅尝装饰器和AOP
  • 原文地址:https://www.cnblogs.com/hushaojun/p/7990951.html
Copyright © 2011-2022 走看看