• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > 总结UNIX/LINUX下C++程序计时的方法

总结UNIX/LINUX下C++程序计时的方法

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-28

通过本文主要向大家介绍了linux与unix的区别,unix/linux是什么,unix/linux操作系统,unix&linux大学教程,linux和unix等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

前言

良好的计时器可帮助程序开发人员确定程序的性能瓶颈,或对不同算法进行性能比较。但要精确测量程序的运行时间并不容易,因为进程切换、中断、共享的多用户、网络流量、高速缓存访问及转移预测等因素都会对程序计时产生影响。

下面看看小编为大家整理几个计时方法

方法一:

如果是想统计某个程序的运行时间,那么可以使用

time ./a.out
</div>

方法二:

如果是想对某个函数或者语句进行计时,那么有别的方法。比如说,gettimeofday函数。直接贴示例代码:

#include <sys/time.h>
void f()
{
 //...
}
int main()
{
 struct timeval t1, t2;
 gettimeofday(&t1, NULL);
 f();
 gettimeofday(&t2, NULL);
 //那么函数f运行所花的时间为
 //deltaT = (t2.tv_sec-t1.tv_sec) * 1000000 + t2.tv_usec-t1.tv_usec 微秒
 return 0;
}
</div>

gettimeofday只能精确到微秒,并且它受系统时钟的影响(它的原理就是通过读取系统时钟,因此当计时的这段时间里有其他程序修改了系统时钟,那么结果将不准确)。

如果想精确到纳秒呢?继续往下看:

方法三:

#include <time.h>
void f()
{
 //...
}
int main()
{
 timespec t1, t2;
 clock_gettime(CLOCK_MONOTONIC, &t1);
 f();
 clock_gettime(CLOCK_MONOTONIC, &t2);
 //那么f所花时间为
 //deltaT = (t2.tv_sec - t1.tv_sec) * 10^9 + t2.tv_nsec - t1.tv_nsec 纳秒
 return 0;
}
</div>

这里说的都是wall clock,如果想获得cpu执行时间,以及了解clock_gettime参数的解释和可能的取值,可以man一下。

总结

以上就是在UNIX/LINUX下C++程序计时的方法的全部内容,希望本文的内容对大家学习使用C++程序能有所帮助。如有疑问欢迎大家留言讨论。

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 总结UNIX/LINUX下C++程序计时的方法

相关文章

  • 2017-05-28Windows消息传递机制详解
  • 2017-05-28C 创建链表并将信息存储在二进制文件中读取的实例代码
  • 2017-05-28C语言实现奇数阶魔方阵的方法
  • 2017-05-28如何判断一个数是否为4的幂次方?若是,并判断出来是多少次方?
  • 2017-05-28二分法求多项式在-10 10间值的实现代码
  • 2017-05-28linux之sed命令的用法
  • 2017-05-28C语言中打印特殊图案的实现代码
  • 2017-05-28基础C语言编程时易犯错误有哪些
  • 2017-05-28C++空类详解
  • 2017-05-28C++基于CreateToolhelp32Snapshot获取系统进程实例

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • C语言字符串操作总结大全(超详细)
    • c++运算符重载基础知识详解
    • C语言中使用快速排序算法对元素排序的实例详解
    • 浅谈C语言中strcpy,strcmp,strlen,strcat函数原型
    • 详解C++编程中对于函数的基本使用
    • C++中用substr()函数消除前后空格的解决方法详解
    • C语言实现奇数阶魔方阵的方法
    • 载入内存,让程序运行起来
    • C语言二叉树的非递归遍历实例分析
    • c语言实现顺序表的基本操作

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有