以下所有代码都有使用Sleep()延时函数,需 #include <Windows.h>

1.使用clock(),ms级别计时器 :

        double start = clock();Sleep(1000);double end = clock();double last = start - end;cout << last << "ms" << endl;

使用时需要包含头文件<ctime>

2. 使用GetTickCount(),ms级别计时器 :

        double start = GetTickCount(); //计时器Sleep(2000);double end = GetTickCount();double last = start - end;cout << last << "ms" << endl;

使用时需包含<Window.h>

3.使用getTickCount(),ms级别计时器:

        double start = getTickCount();//开始时间Sleep(2000);double end = getTickCount();double last = (end - start) * 1000 / getTickFrequency();cout << last << "ms" << endl;

这是opencv 所带计时器,使用时需#include <opencv2/opencv.hpp>,前面那个GetTickCount()是win的API。

4.使用time(NULL),s级别计时器:

        double start, stop, durationTime;start = time(NULL);Sleep(2000);stop = time(NULL);durationTime = (double)difftime(stop, start);cout << "程序耗时:" << durationTime << " s" << endl;

需要包含<ctime>

5.微秒级计时器QueryPerformance:

        LARGE_INTEGER cpuFreq;LARGE_INTEGER startTime;LARGE_INTEGER endTime;QueryPerformanceFrequency(&cpuFreq);QueryPerformanceCounter(&startTime);Sleep(1000);QueryPerformanceCounter(&endTime);double last = (((endTime.QuadPart - startTime.QuadPart) * 1000000) / cpuFreq.QuadPart);cout << last << " us" << endl;

需要包含<Windows.h>

还可以将其封装为一个类:

class stop_watch
{
public:stop_watch(): elapsed_(0){QueryPerformanceFrequency(&freq_);}~stop_watch() {}
public:void start(){QueryPerformanceCounter(&begin_time_);}void stop(){LARGE_INTEGER end_time;QueryPerformanceCounter(&end_time);elapsed_ += (end_time.QuadPart - begin_time_.QuadPart) * 1000000 / freq_.QuadPart;}void restart(){elapsed_ = 0;start();}//微秒double elapsed(){return static_cast<double>(elapsed_);}//毫秒double elapsed_ms(){return elapsed_ / 1000.0;}//秒double elapsed_second(){return elapsed_ / 1000000.0;}private:LARGE_INTEGER freq_;LARGE_INTEGER begin_time_;long long elapsed_;
};int main()
{stop_watch watch;watch.start();Sleep(2000);watch.stop();cout << watch.elapsed() << endl;
}

6.C++11 chrono库,微秒级别计时器

        auto start = steady_clock::now();Sleep(1000);auto end = steady_clock::now();auto last = duration_cast<microseconds>(end - start);cout <<  last.count() << "um";

需要包含头文件 #include <chrono>并且using namespace std::chrono;

六种c++计时器函数(秒级到微妙级)相关推荐

  1. stm32实现Systick的毫秒级延时和微妙级延时

    学习目标: stm32实现Systick的毫秒级延时和微妙级延时 学习内容: 1.Systick 工作原理 Systick(系统定时器)是ARM Cortex M3/M4 内核的一个外设,因为所有的C ...

  2. python 时间格式转换,秒级和毫秒级时间戳转换

    1. 时间格式转换 # -*- coding=utf8 -*- import datetime import time import pytzutc = "2017-07-28T08:28: ...

  3. 单片机计时器100000秒以内

    单片机计时器100000秒以内 硬件连接: 代码: #include <reg52.h> #include <intrins.h> #define uchar unsigned ...

  4. Linux平台C++ 实现毫秒/微妙级时间获取或者延时

    1. 微妙级时间获取 所用头文件 //c++11日期和时间库:chrono #include <chrono> using namespace std::chrono;chrono::sy ...

  5. C 语言时间函数 秒 毫秒 微秒

    一.将时间戳转成字符串 //strfmt void metis_strftime(time_t t, char *pcTime) {struct tm *tm_t;tm_t = localtime(& ...

  6. 通过父级id获取到其下所有子级(无穷级)——Mysql函数实现

    [需求]某用户只能查看其自己信息及其下级信息,涉及通过该用户所在部门获取其下所有部门(多层)id集合. 步骤一:对数据库进行设置: set global log_bin_trust_function_ ...

  7. 51nod图论题解(4级,5级算法题)

    51nod图论题解(4级,5级算法题) 1805 小树 基准时间限制:1.5 秒 空间限制:131072 KB 分值: 80 难度:5级算法题 她发现她的树的点上都有一个标号(从1到n),这些树都在空 ...

  8. 【Linux】基础IO --- 内核级和用户级缓冲区、磁盘结构、磁盘的分治管理、block group块组剖析…

    出身寒微,不是耻辱.能屈能伸,方为丈夫. 文章目录 一.缓冲区(语言级:IO流缓冲,内核级:块缓冲) 1.观察一个现象 2.理解缓冲区存在的意义(节省进程IO数据的时间) 3.语言级缓冲区的刷新策略( ...

  9. Oracle锁表 行级锁 表级锁 行级锁

    2019独角兽企业重金招聘Python工程师标准>>> Oracle锁表  行级锁  表级锁 ---- 行被排他锁定 ----在某行的锁被释放之前,其他用户不能修改此行       ...

最新文章

  1. php类的测试用例,快速入门:集成 PHPUnit 编写测试用例
  2. laravel Collection mapToDictionary 例子
  3. linux du -hd1查看文件及目录所占磁盘空间
  4. 在大厂做螺丝钉?还是去新赛道攻城略地?看看这届年轻人怎么说
  5. Springboot是什么?Springboot详解!入门介绍
  6. Hadoop伪分布式集群的安装部署
  7. 服务器关于数据流转方式
  8. 失去了商标品牌的迅雷大数据,变成了摸金狗?
  9. iText的一些总结
  10. Visio| Visio简易使用指南
  11. eplan好看的电缆图表_EPLAN电缆图表模板
  12. javascript gba游戏模拟器
  13. 金蝶K3系统物料主数据后台表对应字段一览
  14. JobScheduler布置后台任务以及实现进程保活?
  15. 中国的程序员培训是不是有问题?
  16. 机器人断脚_超强算法让机器人脚断了照样跑
  17. This application’s application-identifier entitlement does not match that of the installed applicati
  18. vue-iview异步加载渲染树
  19. Win10解决Windows Media Player在播放文件时遇到问题
  20. 2020身高体重标准表儿童_2020儿童身高体重标准表

热门文章

  1. 【高效软件】推荐一款多功能PDF转换器,在线转换永久免费
  2. MyBatis异常报告: Mapper method ‘com.dao.UserMapper.insert attempted to return null from a method with ……
  3. Android监控电池电量和充电状态
  4. iCloud如何只清理本地缓存而不删除云端文件
  5. beyond compare linux中文包,linux 下安装 Beyond Compare
  6. C++--顺时针打印矩阵
  7. 计算机专业看重CPU还是显卡,组装电脑时CPU和显卡选择哪个重要?
  8. android x86 最新手机,Android-x86手机PC版的引导方法
  9. 题目4:一球从100米高度自由落下,每次落地后反跳回原高度的一半;再落下,求它在第10次落地时,共经过多少米?第10次反弹多高?
  10. 开盘15分钟内扑捉当天黑马