[C/C++]C/C++计算代码的运行时间
有很多时候,实现一个功能后可能不仅仅要效果,还要效率,如果可以在极短的时间内完成一个功能那当然是最好不过的啦,但是可能经常会事与愿违。
这里就写一下,都可以怎样用C/C++或者Qt的方法来测试代码的运行时间。
一、C/C++方法
1.1 clock_t方法
clock_t方法需要包含头文件<time.h>,clock_t是一个长整型数字,它可以将时间精确到毫秒级别:
#include <time.h>
clock_t start, finish;
start = clock();
...
function();
...
finish = clock();
int duration = finish - start;
double durationS = (double)duration / CLOCKS_PER_SEC;//如果需要换算成秒
1.2 使用windows API 1
头文件#include<Windows.h>,主要函数GetTickCount(),能达到毫秒级别:
#include <Windows.h>
DWORD start_time = GetTickCount();
...
function();
...
DWORD end_time = GetTickCount();
DWORD duration = start_time - end_time;
1.3 使用Windows API 2
头文件依然是#include<Windows.h>,但是这次不一样,可以达到微秒级别:
#include <windows.h>
double run_time;
_LARGE_INTEGER time_start; //开始时间
_LARGE_INTEGER time_over; //结束时间
double dqFreq; //计时器频率
LARGE_INTEGER f; //计时器频率
QueryPerformanceFrequency(&f);
dqFreq=(double)f.QuadPart;
QueryPerformanceCounter(&time_start); //计时开始
...
function();
...
QueryPerformanceCounter(&time_over); //计时结束
//乘以1000000把单位由秒化为微秒,精度为1000 000/(cpu主频)微秒
run_time=1000000*(time_over.QuadPart-time_start.QuadPart)/dqFreq;
也可以这么用的:
LARGE_INTEGER nFreq; LARGE_INTEGER t1;
LARGE_INTEGER t2;
QueryPerformanceFrequency(&nFreq);
QueryPerformanceCounter(&t1);
double dtStart = t1.QuadPart;
...
function();
...
QueryPerformanceCounter(&t2);
double dtEnd = t2.QuadPart; //后面的1000表示毫秒整数,微秒小数
double elapsed = (dtEnd - dtStart) / (double)nFreq.QuadPart * 1000;
二、Qt方法
Qt方法的话主要还是用到QTime类,Qt的方法基本上都只能精确到毫秒级别。
QTime startTime = QTime::currentTime();
...
function();
...
QTime stopTime = QTime::currentTime();
int elapsed = startTime.msecsTo(stopTime);
要注意这个方法的是,如果你的代码块运行时间超级短,或者说是达到几个毫秒的级别的话,这个方法慎用,有毒,有时候直接就是0。
另一个也是Qt的QTime的方法,也是毫秒级别的,也是慎用:
QTime time;
time.start();
...
function();
...
int timeElapsed = time.elapsed();
三、结论
我个人的话,会相对比较推荐用clock_t的方法吧,这个好像是C/C++的东西,不算windows API的吧,一般来说冲突会相对比较少吧,如果对时间要求达到毫秒级别就满足的话,那如果是要达到微秒级别,那就没办法,暂时能找到的也就是1.3方法提到的window API 2的方法,但是这个因为直接用windows API,我竟然在某些场合下出现冲突的情况!!!
泪眼问花花不语,乱红飞过秋千去。
[C/C++]C/C++计算代码的运行时间的更多相关文章
- C语言--计算代码段运行时间
c语言中有专一包含计算时间函数的头文件,time.h.当我们需要计算某段程序运行的时间时就需要用到time.h包含的clock()函数,在这里介绍一下如何使用这个函数计算代码运行时间. clock函数 ...
- Objective-C 计算代码运行时间
今天看到一篇关于iOS应用性能优化的文章,其中提到计算代码的运行时间,觉得非常有用,值得收藏.不过在模拟器和真机上是有差异的,以此方法观察程序运行状态,提高效率. 第一种:(最简单的NSDate) N ...
- 使用console进行 性能测试 和 计算代码运行时间(转载)
本文转载自: 使用console进行 性能测试 和 计算代码运行时间
- 使用console进行 性能测试 和 计算代码运行时间
原文:http://www.tuicool.com/articles/JrARVjv 对于前端开发人员,在开发过程中经常需要监控某些表达式或变量的值,如果使用用 debugger 会显得过于笨重,最常 ...
- 使用console进行性能测试和计算代码运行时间
对于前端开发人员,在开发过程中经常需要监控某些表达式或变量的值,如果使用用debugger会显得过于笨重,最常用的方法是会将值输出到控制台上方便调试.最常用的语句就是console.log(expre ...
- 三种计算c#程序运行时间的方法
三种计算c#程序运行时间的方法 第一种: 利用 System.DateTime.Now // example1: System.DateTime.Now method DateTime dt1 = S ...
- C:clock() 计算代码执行时间
clock():捕捉从程序开始运行到clock()被调用时所耗费的事件. 这个时间的单位是 clock tick,即时钟打点 常数 CLK_TCK:机器时钟每秒走的时钟打点数 要使用这个函数需要包含头 ...
- iOS测试一段代码的运行时间
王刚韧 23:19:26测试一段代码的运行时间 测试一段代码运行花了多久: NSDate* tmpStartData = [NSDate date] ;<#代码#> double delt ...
- python基础:测量python代码的运行时间
Python社区有句俗语:“python自己带着电池” ,别自己写计时框架.Python 2.3 具备一个叫做 timeit 的完美计时工具可以测量python代码的运行时间. timeit模块 ti ...
随机推荐
- P1056 组合数的和
P1056 组合数的和 转跳点:
- OI生涯回顾
OI回忆录只是一个预告,估计等2020高考结束才放出来吧. 先写一下自己简单的OI历程吧: 小升初刚起步 初一 第一次比赛,NOIP PJ组215分,踩线1=,全省rk86,全国rk677(毕竟AH ...
- 【LeetCode】合并两个有序数组
[问题] 给定两个有序整数数组 nums1 和 nums2,将 nums2 合并到 nums1 中,使得 num1 成为一个有序数组. 说明:初始化 nums1 和 nums2 的元素数量分别为 m ...
- String巩固
About String in Java 如今做了一个重大决定,不定期温习The Basement Of Java String对象的认知简述 首先 String不属于 8种基本数据类型, Strin ...
- module已经装了但仍提示找不到的解决方法
今天遇到的问题:(这里只是个例子) 解决方法: npm clean cache --force 删了node_modules 和 package-lock ,然后npm install 如果再不行,看 ...
- springboot - 返回JSON error 从自定义的 ErrorController
使用AbstractErrorController(是ErrorController的实现),返回json error. 1.概览 2.基于<springboot - 映射 /error 到自定 ...
- CCCC L3-015. 球队“食物链”(dfs+剪枝)
题意: 某国的足球联赛中有N支参赛球队,编号从1至N.联赛采用主客场双循环赛制,参赛球队两两之间在双方主场各赛一场. 联赛战罢,结果已经尘埃落定.此时,联赛主席突发奇想,希望从中找出一条包含所有球队的 ...
- AVCodec 结构体
typedef struct AVCodec { // 标示Codec 的名字, 比如,"h264" "h263" 等. const char *name; / ...
- springboot + shiro+登录 微信登录 次数验证资料
分享一个朋友的人工智能教程.零基础!通俗易懂!风趣幽默!大家可以看看是否对自己有帮助,点击查看教程. 1.https://blog.csdn.net/xtiawxf/article/details/5 ...
- PWC6199:Generated servlet error:Only a type can be imported. org.apache.jasper.tagplugins.jstl.core.ForEach resolves to a package
<%@ import="org.apache.jasper.tagplugins.jstl.core.ForEach"%> 去掉这条语句,就不报错了.所以问题就出在这里 ...