码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • linux上获取时间的性能评估


    #include
    #include
    #include
    #include

    int foo(int i)
    {
        return i;
    }

    const int64_t MAX_COUNT = 100000*10000;

    struct TimerEval {
      TimerEval(const char* module)
      {
          start_time_ = time(NULL);
          module_ = module;
      }
      ~TimerEval()
      {
          time_t end_time = time(NULL);
          printf("%s    elapse : %ld sec\n", module_, (end_time - start_time_));
      }
      time_t start_time_;
      const char* module_;
    };

    int main()
    {
        struct timeval tpTmp;

        printf("repeat %ld times, test result is : \n", MAX_COUNT);

        {   
            TimerEval eval("call fun");
            for (int i=0; i             foo(i);
        }   

        {   
            TimerEval eval("call time");
            for (int i=0; i             time(NULL);;
        }   

        {   
            TimerEval eval("call gettimeofday");
            for (int i=0; i             gettimeofday(&tpTmp, NULL);;
        }   
        
        {   
            TimerEval eval("call clock_gettime");
            struct timespec tp; 
            for (int i=0; i             clock_gettime(CLOCK_REALTIME, &tp);
        }   

        return 0;
    }

    两次测试结果为(MAX_COUNT不同):

    repeat 100000000 times, test result is : 
    call fun    elapse : 0 sec
    call time    elapse : 0 sec
    call gettimeofday    elapse : 1 sec
    call clock_gettime    elapse : 2 sec

    repeat 1000000000 times, test result is : 
    call fun    elapse : 1 sec
    call time    elapse : 2 sec
    call gettimeofday    elapse : 13 sec
    call clock_gettime    elapse : 13 sec

  • 相关阅读:
    IDEA版SSM入门到实战(Maven+MyBatis+Spring+SpringMVC) -Maven核心概念
    统计分布的 参数估计函数-Matlab命令
    el-table 懒加载自动展开节点
    利用MATLAB创建栅格地图(代码可复制)
    基于Java的学生学籍管理系统设计与实现(源码+lw+部署文档+讲解等)
    01背包、完全背包、多重背包、分组背包总结
    【非纯小白勿进】计算机的基本操作
    开源与闭源:大模型时代的技术交融与商业平衡
    速卖通自养号测评:如何规避安全风险?
    案例丨低代码快速开发平台在信息安全企业里的应用
  • 原文地址:https://blog.csdn.net/XUZHENG19860228/article/details/127986211
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号