日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

Window系统下C/C++程序毫秒和微秒级程序运行时间的获取方法

發布時間:2024/9/21 c/c++ 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Window系统下C/C++程序毫秒和微秒级程序运行时间的获取方法 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

一、使用clock()函數,獲取毫秒級(ms)時間[1]

#include <time.h>//clock()頭文件

clock_t start = clock();

???{statement section}//測試代碼段

clock_t end = clock();

printf("the running time is :%fs\n", (double)(end -start)/(double)CLOCKS_PER_SEC); //秒

?

二、基于CPU級的方法,獲取微秒級(us)時間[2,3]

#include <stdio.h>
#include <windows.h>//頭文件

LARGE_INTEGER nFreq;

LARGE_INTEGER t1;

LARGE_INTEGER t2;

double dt;

?QueryPerformanceFrequency(&nFreq);
?QueryPerformanceCounter(&t1);

??????{statementsection}//測試代碼段
??QueryPerformanceCounter(&t2);
??dt = (t2.QuadPart - t1.QuadPart) / (double)nFreq.QuadPart;
??cout<<"Running time :"<<dt*1000<<"ms"<<endl;//dt結果乘以1000,將顯示時間調整到ms級別顯示,乘以1000000,將顯示時間調整到us級別顯示

備注:可以在代碼段添加Sleep()函數測試,如下兩個測試實例。

例1:500ms

time_t start = clock();
???Sleep(1000);//500ms
time_t end = clock();
printf("the running time is :%fms\n", (double)(end -start));

運行結果,如下:

the running time is :1001.000000ms

例2: 5ms測試?

?LARGE_INTEGER ?nFreq,t1,t2;
double dt;
QueryPerformanceFrequency(&nFreq);
QueryPerformanceCounter(&t1);
Sleep(5);//5ms,其中1ms=1000us
QueryPerformanceCounter(&t2);
?dt = (t2.QuadPart - t1.QuadPart)/(double)nFreq.QuadPart;
cout<<"Running time : "<<dt*1000000<<"us"<<endl;

運行結果,如下:

Running time : 5162.22us
---------------------?
作者:泡泡徐?
來源:CSDN?
原文:https://blog.csdn.net/xpplearnc/article/details/53894048?
版權聲明:本文為博主原創文章,轉載請附上博文鏈接!

總結

以上是生活随笔為你收集整理的Window系统下C/C++程序毫秒和微秒级程序运行时间的获取方法的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。