如何计算C++中精确的代码c 计算程序运行时间间

千里之行 始于足下精诚所至 金石为开
欢迎加入我们,一同切磋技术。 &
用户名: &&&
密 码: &
共有 3589 人关注过本帖
标题:VS2013控制台程序 C++怎么求一个程序的运行时间?
等 级:新手上路
&&问题点数:0&&回复次数:2&&&
VS2013控制台程序 C++怎么求一个程序的运行时间?
显示程序运行时间
搜索更多相关主题的帖子:
等 级:版主
威 望:90
帖 子:966
专家分:4702
程序末尾输出clock()的值,这个是毫秒数。
来 自:神界
等 级:贵宾
威 望:344
帖 子:11297
专家分:44652
#include &stdio.h&
#include &time.h&
int main()
&&& clock_t start,
&&& start=clock();
&&& ......
&&& ......
&&& ......
&&& finish=clock();
&&& printf(&共耗时%.3lf秒&,((double)finish-start)/1000);
&&& return 0;
DO IT YOURSELF !
版权所有,并保留所有权利。
Powered by , Processed in 0.022976 second(s), 8 queries.
Copyright&, BCCN.NET, All Rights ReservedC++中两种常用的记录程序运行时间的方法的总结
我的图书馆
C++中两种常用的记录程序运行时间的方法的总结
关于C++中计算时间的一些总结
方法一:clock()计时函数
clock()是C/C++中的计时函数,而与其相关的数据类型是clock_t。在MSDN中,查得对clock函数定义如下:
clock_t clock(void)
简单而言,就是该程序从启动到函数调用占用CPU的时间。这个函数返回从“开启这个程序进程”到“程序中调用clock()函数”时之间的CPU时钟计时单元(clock
tick)数,在MSDN中称之为挂钟时间(wal-clock);若挂钟时间不可取,则返回-1。其中clock_t是用来保存时间的数据类型。
在time.h文件中,我们可以找到对clock_t()的定义:
&span&style="font-size:14"&#ifndef&_CLOCK_T_DEFINED&&&&&&typedef&long&clock_t;&&#define&_CLOCK_T_DEFINED&&#endif&/span&&&
很明显,clock_t是一个长整形数。在time.h文件中,还定义了一个,它用来表示一秒钟会有多少个时钟计时单元,其定义如下:
#define CLOCKS_PER_SEC ((clock_t)1000)
测试程序:
&span&style="font-size:14"&&span&style="font-size:18"&#include&iostream&&&#include&time.h&&&&&using&namespace&&&&&int&main()&&{&&&&&&clock_t&startTime,endT&&&&&&startTime&=&clock();&&&&&&for&(int&i&=&0;&i&&&1000000;&i++)&&&&&&{&&&&&&&&&&i++;&&&&&&}&&&&&&endTime&=&clock();&&&&&&cout&&&&"Totle&Time&:&"&&&(double)(endTime&-&startTime)&/&CLOCKS_PER_SEC&&&&"s"&&&&&&&&&&system("pause");&&&&&&return&0;&&}&/span&&/span&&&
&span&style="font-size:14"&#include&iostream&&&#include&time.h&&&&&using&namespace&&&&&int&main()&&{&&&&&&for&(int&i&=&0;&i&&&1000000;&i++)&&&&&&{&&&&&&&&&&i++;&&&&&&}&&&&&&cout&&&&"Totle&Time&:&"&&&&(double)clock()&/CLOCKS_PER_SEC&&&"s"&&&&&&&&&&system("pause");&&&&&&return&0;&&}&/span&&&
方法二:GetTickCount()函数:
GetTickCount是函数。GetTickCount返回(retrieve)从操作系统启动所经过(elapsed)的毫秒数,它的返回值是DWORD。
函数原型:
GetTickCount(void);
C/C++头文件:winbase.h
windows程序设计中可以使用头文件
测试代码:
&span&style="font-size:14"&#include&iostream&&&#include&Windows.h&&&&&using&namespace&&&&&int&main()&&{&&&&&&DWORD&start_time&=&GetTickCount();&&&&&&for&(int&i&=&0;&i&&&;&i++)&&&&&&{&&&&&&&&&&i++;&&&&&&}&&&&&&DWORD&end_time&=&GetTickCount();&&&&&&cout&&&&"The&run&time&is:"&&&&(end_time&-&start_time)&&&&"ms!"&&&&&&&&&&system("pause");&&&&&&return&0;&&}&/span&&&注意事项:
GetTickcount函数:它返回从操作系统启动到当前所经过的毫秒数,常常用来判断某个方法执行的时间,其函数原型是DWORD
GetTickCount(void),返回值以32位的双字类型DWORD存储,因此可以存储的最大值是(2^32-1) ms约为49.71天,因此若系统运行时间超过49.71天时,这个数就会归0,中也明确的提到了:"Retrieves
the number of milliseconds that have elapsed since the system was started, up to 49.7 days."。因此,如果是编写端程序,此处一定要万分注意,避免引起意外的状况。
特别注意:这个函数并非实时发送,而是由系统每18ms发送一次,因此其最小精度为18ms。当需要有小于18ms的精度计算时,应使用StopWatch方法进行。
用clock()函数计算运行时间,表示范围一定大于GetTickCount()函数,所以,建议使用clock()函数。
转自:&http://blog.csdn.net/xiong/article/details/
发表评论:
TA的最新馆藏程序的运行效率很重要,为了明确到底是那一块代码浪费时间,浪费多少时间,检测一下是很有必要的,用下面的方法可以精确地统计时间。第一种精确到秒,第二种精确到毫秒,第三种精确到0.000001秒,大家可以根据自己的需求选用。#include&time.h&#include&stdio.h&#include&stdlib.h&#include&windows.h&int main(){
//精确到秒 ==========================================
time_t t1,t2;
time(&t1);
//此处放置要测试的代码
Sleep(1000);//延时
time(&t2);
printf("%d %d %d秒/n",t1,t2,t2-t1);
//精确到毫秒 ========================================
clock_t c1,c2;
c1=clock();
//此处放置要测试的代码
Sleep(100);//延时
c2=clock();
printf("%d %d %d毫秒/n",c1,c2,c2-c1);
//精确到 0.000001毫秒 ===============================
LARGE_INTEGER
LONGLONG start,
double dft, dff,
QueryPerformanceFrequency(&litmp);//获得时钟频率
dff = (double) litmp.QuadP
QueryPerformanceCounter(&litmp);//获得初始值
start = litmp.QuadP
//此处放置要测试的代码
Sleep(1000);//延时
QueryPerformanceCounter(&litmp);//获得终止值
end = litmp.QuadP
dfm = (double) (end - start);
dft = dfm ///获得对应的时间值,单位秒
printf("%lf毫秒/n",dfm/dff*1000);}那是在windows下的,如果在linux环境下,要这样计算时间:struct timeval tv_start,tv_gettimeofday(&tv_start,NULL);//此处放要测试的代码或程序gettimeofday(&tv_end,NULL);printf("程序运行时间为:%lf秒/n",tv_end.tv_sec-tv_start.tv_sec+(tv_end.tv_usec-tv_start.tv_usec)/); //其中timeval的结构题定义是这样的:struct timeval {
/* seconds */
suseconds_t tv_
/* microseconds 微秒=1/10^6秒 */}; tv_sec和tv_usec可以单独输出,根据自己的需求选择精度就可以了
最新教程周点击榜
微信扫一扫1.使用CTime类(获取系统当前时间,精确到秒)
//获取系统时间
tm=CTime::GetCurrentTime();//获取系统日期
str=tm.Format(&现在时间是%Y年%m月%d日 %X&);
MessageBox(str,NULL,MB_OK);
a,从CTimet中提取年月日时分秒
 CTime t = CTime::GetCurrentTime();
  int d=t.GetDay(); //获得几号
  int y=t.GetYear(); //获取年份
  int m=t.GetMonth(); //获取当前月份
  int h=t.GetHour(); //获取当前为几时
  int mm=t.GetMinute(); //获取分钟
  int s=t.GetSecond(); //获取秒
  int w=t.GetDayOfWeek(); //获取星期几,注意1为星期天,7为星期六
b,计算两段时间的差值,可以使用CTimeSpan类,具体使用方法如下:
  CTime t1( , 22, 15, 0 );
CTime t = CTime::GetCurrentTime();
CTimeSpan span=t-t1; //计算当前系统时间与时间t1的间隔
  int iDay=span.GetDays(); //获取这段时间间隔共有多少天
  int iHour=span.GetTotalHours(); //获取总共有多少小时
  int iMin=span.GetTotalMinutes();//获取总共有多少分钟
  int iSec=span.GetTotalSeconds();//获取总共有多少秒
c,获得当前日期和时间,并可以转化为CString
  CTime tm=CTime::GetCurrentTime(); CString str=tm.Format(&%Y-%m-%d&);//显示年月日
2.使用GetLocalTime:Windows API 函数,获取当地的当前系统日期和时间 (精确到毫秒)
  此函数会把获取的系统时间信息存储到SYSTEMTIME结构体里边
  typedef struct _SYSTEMTIME
  WORD wY//年
  WORD wM//月
  WORD wDayOfW//星期:0为星期日,1为星期一,2为星期二&&
  WORD wD//日
  WORD wH//时
  WORD wM//分
  WORD wS//秒
  WORD wM//毫秒
  }SYSTEMTIME,*PSYSTEMTIME;
SYSTEMTIME
CString strDate,strT
GetLocalTime(&st);
strDate.Format(&%4d-%2d-%2d&,st.wYear,st.wMonth,st.wDay);
strTime.Format(&%2d:%2d:%2d&,st.wHour,st.wMinute,st.wSecond) ;
AfxMessageBox(strDate);
AfxMessageBox(strTime);
3.使用GetTickCount:从操作系统启动到现在所经过(elapsed)的毫秒数,它的返回值是DWORD。(精确到毫秒)
//获取程序运行时间
long t1=GetTickCount();//程序段开始前取得系统运行时间(ms)
Sleep(500);
long t2=GetTickCount();();//程序段结束后取得系统运行时间(ms)
str.Format(&time:%dms&,t2-t1);//前后之差即 程序运行时间
AfxMessageBox(str);
//获取系统运行时间
long t=GetTickCount();
CString str,str1;
str1.Format(&系统已运行 %d时&,t/3600000);
t%=3600000;
str1.Format(&%d分&,t/60000);
str+=str1;
str1.Format(&%d秒&,t/1000);
str+=str1;
AfxMessageBox(str);
4.使用time_t time( time_t * timer ) :
仅使用C标准库(精确到秒)
得到从标准计时点(一般是日午夜)到当前时间的秒数
  计算时间差:double difftime( time_t timer1, time_t timer0)
struct tm *localtime(const time_t *timer);
取得当地时间,localtime获取的结果由结构tm返回
返回的字符串可以依下列的格式而定:
%a 星期几的缩写。Eg:Tue
%A 星期几的全名。 Eg: Tuesday
%b 月份名称的缩写。
%B 月份名称的全名。
%c 本地端日期时间较佳表示字符串。
%d 用数字表示本月的第几天 (范围为 00 至 31)。日期
%H 用 24 小时制数字表示小时数 (范围为 00 至 23)。
%I 用 12 小时制数字表示小时数 (范围为 01 至 12)。
%j 以数字表示当年度的第几天 (范围为 001 至 366)。
%m 月份的数字 (范围由 1 至 12)。
%p 以 ''AM'' 或 ''PM'' 表示本地端时间。
%U 数字表示为本年度的第几周,第一个星期由第一个周日开始。
%W 数字表示为本年度的第几周,第一个星期由第一个周一开始。
%w 用数字表示本周的第几天 ( 0 为周日)。
%x 不含时间的日期表示法。
%X 不含日期的时间表示法。 Eg: 15:26:30
%y 二位数字表示年份 (范围由 00 至 99)。
%Y 完整的年份数字表示,即四位数。 Eg:2008
%Z(%z) 时区或名称缩写。Eg:中国标准时间
%% % 字符。
5.要获取高精度时间,可以使用
BOOL QueryPerformanceFrequency(LARGE_INTEGER *lpFrequency)获取系统的计数器的频率
BOOL QueryPerformanceCounter(LARGE_INTEGER *lpPerformanceCount)获取计数器的值
然后用两次计数器的差除以Frequency就得到时间。
6.还有David的文章中提到的方法:
Multimedia Timer Functions
The following functions are used with multimedia timers.
timeBeginPeriod/timeEndPeriod/timeGetDevCaps/timeGetSystemTime
timeGetTime/timeKillEvent/TimeProc/timeSetEvent 精度很高
GetTickCount()函数,说是毫秒记数,是真的吗,还是精确到55毫秒?
GetTickCount()和GetCurrentTime()都只精确到55ms(1个tick就是55ms)。如果要精确到毫秒,应该使用timeGetTime函数或QueryPerformanceCounter函数。具体例子可以参考QA001022 &VC++中使用高精度定时器&、QA001813 &如何在Windows实现准确的定时&和QA004842 &timeGetTime函数延时不准&。
vc++怎样获取系统时间,返回值是什么类型的变量呢?
GetSystemTime返回的是格林威志标准时间
VOID GetSystemTime(
LPSYSTEMTIME lpSystemTime // address of system time structure
函数就可以获得了,其中LPSYSTEMTIME 是个结构体
含:年,月,日,周几,小时,分,秒,毫秒。[喝小酒的网摘]/a/16370.htm[喝小酒的网摘]/a/16370.htm
IP:218.94.158.227:CTimeSpan
获取毫秒差IP:114.248.147.63:vc 获取当前时间 毫秒IP:222.131.123.234:CTime信息如何提取毫秒IP:222.131.123.234:vc获取毫秒IP:61.148.123.214:VC time_t 含有毫秒IP:180.157.173.146:VC6 ctime 毫秒IP:112.85.56.48:vc 获取1970 秒IP:58.240.218.82:精确到毫秒的定时器IP:60.12.143.126:获取系统精确时间APIIP:116.25.4.27:VC 时间 毫秒 1970IP:182.148.74.75:vc GetLocalTime 1970IP:211.102.149.17:vc CTime 秒换算小时IP:110.52.156.150:CTime::GetCurrentTime() 毫秒IP:120.6.20.224:getcurrenttime精确IP:27.151.122.49:VC
time_t什么方法能得到毫秒IP:60.190.244.158:VC
把当前时间转化为毫秒数IP:113.116.137.203:VC获取现在的毫秒数IP:219.239.6.5:vc 获取时间 毫秒IP:61.135.190.222:系统日期转化为毫秒IP:122.234.243.142:bcb 遍历所有窗口IP:121.19.167.99:如何提取应用程序运行时间IP:119.137.18.98:系统日期转化为毫秒 VCIP:180.159.75.169:GetTickCount 精确到毫秒IP:58.54.252.226:GetDayOfWeek 获取错误IP:123.245.2.51:vc 日期时间毫秒IP:59.40.244.169:VC获取系统时间到毫秒级IP:27.17.16.114:VC 获取纪元秒时间IP:117.79.233.222:CTime如何获得以毫秒为单位的当前时间IP:221.6.206.38:vc获取当前系统时间毫秒数IP:116.226.45.219:ctime获取毫秒C++ 获取代码运行时间的各种方法_百度文库
两大类热门资源免费畅读
续费一年阅读会员,立省24元!
C++ 获取代码运行时间的各种方法
上传于||文档简介
&&C++ 获取 代码运行 时间 的 各种方法
阅读已结束,如果下载本文需要使用2下载券
想免费下载本文?
定制HR最喜欢的简历
下载文档到电脑,查找使用更方便
还剩5页未读,继续阅读
定制HR最喜欢的简历
你可能喜欢

我要回帖

更多关于 matlab 计算运行时间 的文章

 

随机推荐