扩展阅读
  • linux c/c++ IP字符串转换成可比较大小的数字
  • 在win分区上安装linux和独立分区安装linux有什么区别?可以同时安装吗?(两个linux系统)
  • linux哪个版本好?linux操作系统版本详细介绍及选择方案推荐
  • 在虚拟机上安装的linux上,能像真的linux系统一样开发linux程序么?
  • secureCRT下Linux终端汉字乱码解决方法
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在有linux的盘)
  • Linux c字符串中不可打印字符转换成16进制
  • 红旗Linux主机可以通过127.0.0.1访问,但如何是连网的Win2000机器通过Linux的IP去访问Linux
  • Linux常用命令介绍:更改所属用户群组或档案属性
  • 安装vmware软件,不用再安装linux系统,就可以模拟linux系统了,然后可以在其上学习一下LINUX下的基本操作 了?
  • linux命令大全详细分类介绍及常用linux命令文档手册下载
  • 我重装window后,把linux的引导区覆盖了,进不了linux怎么办?急啊,望热心的人帮助 (现在没有linux的盘,只有DOS启动盘)
  • Docker官方镜像将会使用Alpine Linux替换Ubuntu
  • 如何让win2000和linux共存。我装好WIN2000,再装LINUX7.0,但LILO只能找到LINUX,不能引导WIN2000
  • Linux下chmod命令详细介绍及用法举例
  • 在windows中的VMware装了个linux,主板有两个串口,能做windows和linux的串口通信测试么,怎么测试这两个串口在linux是有效
  • linux僵尸(zombie)进程介绍及清除
  • 我们网站的服务器从windows2000迁往linux,ASP程序继续使用,可是我连LINUX的皮毛都不了解,大家告诉我LINUX下怎么建网站??
  • Linux c++库boost unordered_set数据插入及查找代码举例
  • 中文Linux与西文Linus分别哪一个版是权威?I认为是:中科软的白旗Linux与西文的绿帽子Linux!大家的看法呢?
  • unix/Linux下c++ boost thread库读写锁介绍
  • Windows2000和Linux双操作系统,Linux系统有问题,我直接把Linux分区删除后,Windows2000进不去了,怎么办???
  •  
    当前位置:  编程语言>c/c++

    Linux下gettimeofday()函数和clock()函数:精确到毫秒级的时间

     
        发布时间:2014-3-26  


        本文导语:  Linux下gettimeofday()函数和clock()函数:精确到毫秒级的时间 使用Linux的gettimeofday函数可以达到获取精确到毫秒级的时间,其中t1=t_start.tv_sec是公元1970年至今的时间(换算为秒),t2=t_start.tv_usec是当前秒数下的微秒,所以将t1*...

      Linuxgettimeofday()函数clock()函数:精确到毫秒级的时间

      使用Linux的gettimeofday函数可以达到获取精确到毫秒级的时间,其中t1=t_start.tv_sec是公元1970年至今的时间(换算为秒),t2=t_start.tv_usec是当

    秒数下的微秒,所以将t1*1000+t2/1000可以得到当前的毫秒数。

      gettimeofday()函数原型及相关数据结构:  

    int gettimeofday(struct timeval *tv, struct timezone *tz);
    int settimeofday(const struct timeval *tv , const struct timezone *tz);
    struct timeval {
        time_t      tv_sec;     /* seconds */
        SUSEconds_t tv_usec;    /* microseconds */
    };
    struct timezone {
        int tz_minuteswest;     /* minutes west of Greenwich */
        int tz_dsttime;         /* type of DST correction */
    };

      gettimeofday()函数代码举例1

    #include <stdio.h>
    #include <sys/time.h>
    #include <time.h>
    int gettimeofday(struct timeval *tv, struct timezone *tz);
    int main(int argc,char * argv[])
    {
    struct timeval t_start,t_end;
    long cost_time = 0;
    //get start time
    gettimeofday(&t_start, NULL);
    long start = ((long)t_start.tv_sec)*1000+(long)t_start.tv_usec/1000;
    printf("Start time: %ld msn", start);
    sleep(2);
    usleep(5000);//5毫秒
    //get end time
    gettimeofday(&t_end, NULL);
    long end = ((long)t_end.tv_sec)*1000+(long)t_end.tv_usec/1000;
    printf("End time: %ld msn", end);
    //calculate time slot
    cost_time = end - start;
    printf("Cost time: %ld msn", cost_time);
    return 0;
    }

      gettimeofday()函数代码举例2

    struct timeval t_start,t_end;
    long cost_time = 0;
    //get start time
    gettimeofday(&t_start, NULL);
    printf("Start time: %ld us", t_start.tv_usec);
    //some operation
    …
    //get end time
    gettimeofday(&t_end, NULL);
    printf("End time: %ld us", t_end.tv_usec);
    //calculate time slot
    cost_time = t_end.tv_usec - t_start.tv_usec;
    printf("Cost time: %ld us", cost_time);
    …


    输出

    Start time: 438061 us

    End time: 459867 us

    Cost time: 21806 us


     gettimeofday()函数代码举例3:


    #include <stdio.h>
    #include <sys/time.h>
    #include <time.h>
    int main(int argc, char * argv[]){
        struct timeval tv;                //(1)
        while(1){
            gettimeofday(&tv, NULL);      //(2)
            printf("time %u:%un", tv.tv_sec, tv.tv_usec);
            sleep(2);
        }
        return 0;
    }


        clock()函数返回的是程序运行过程中耗掉得process time,也就是CPU time,CLOCKS_PER_SEC用来表示一秒钟会有多少个时钟计时单元,也就是硬件滴答数。通过clock()函数获取的值可实现精确到毫秒级的时间。

       clock()函数代码举例:

    int main(int argc, char **argv)
    {
    clock_t t1=clock();
    ifstream in("data.txt");
    vector<int> v;
    for(int a;in>>a;v.push_back(a));
    cout<<v.size()<<endl;
    for(int i=0;i<v.size();i++)
    cout<<v[i]<<" ";
    cout<<endl;
    clock_t t2=clock();
    cout<<"TotalTime:"<<t2-t1<<"ms"<<endl;
    }


    相关文章推荐:
  • Linux/CentOS下的CST和UTC时间的区别以及不一致的解决方法
  • linux设置时间和把时间从UTC转成本地时间的
  • Linux下用ntpdate同步时间及date显示设置时间
  • 求助,Linux系统时间总比硬件时间慢!
  • linux c程序运行cpu时间不包括 i/o时间
  • Linux下如何判断系统当前时间和一个表里面已有的时间的大小?
  • Debian linux 开机一段时间后没声音,重启后,一段时间内有声音,然后就没音了.
  • linux有什么命令能把时间戳转换成时间字符串?
  • 如何通过输入时间对linux时间进行设置
  • 请教如何将多台linux的时间,以一台时间为标准达到同步,请高手指教
  • !!请各位大牛帮忙了,在linux下提取系统时间的话,用什么方法能提取到比毫秒更精确的时间呢?
  • 求助,linux中修改了目录dir下的某个文件,相应的dir属性中的时间会与修改目录下文件的时间一致,这是怎么实现的?
  • !!linux下文件名称以时间结尾的,如何在shell脚本中找到时间最新的那个文件?
  • 急问:如何得到linux下c程序运行中的IO等待时间?
  • 嵌入式linux的时间问题
  • [LINUX]内核时间概念
  • Linux 时间设置问题
  • 装了linux后,我的win2000和linux的时间老是都不对了
  • 在linux上如何知道文件的详细信息,如创建和结束时间等?
  • 求教:Linux系统如何保证系统时间运行?
  • linux虚拟机时间与windows时间如何同步


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3