获取代码运行时间,获取当前系统时间,日期
2013-04-26 16:34
585 查看
如何获取代码运行时间
在调试中,经常需要计算某一段代码的执行时间,下面给出两种常用的方式:
第一种:使用GetTickCount函数
注:GetTickCount函数返回从系统运行到现在所经历的时间(类型为DWORD),单位为ms,因为DWORD表示范围的限制,所以使用此种方法存在限制,即系统的运行时间的ms表示不能超出DWORD的表示范围。
第二种:使用clock()函数
clock_t,clock()定义于time.h中,clock()返回从程序运行时刻开始的时钟周期数,类型为long.CLOCKS_PER_SEC定义了每秒钟包含多少了时钟单元数,因为计算ms,所以*1000。
由上面分析可知,用clock()函数计算运行时间,表示范围一定大于GetTickCount()函数,所以,建议使用clock()函数。
1.获取系统时间 (使用CTime类 )
2: 得到系统时间日期 (使用GetLocalTime)
3.获取程序运行时间 (使用GetTickCount)
在调试中,经常需要计算某一段代码的执行时间,下面给出两种常用的方式:
第一种:使用GetTickCount函数
#include<iostream> include<windows.h> using namespace std; int main() { DWORD start_time=GetTickCount(); { //此处为被测试代码 } DWORD end_time=GetTickCount(); cout<<"The run time is:"<<(end_time-start_time)<<"ms!"<<endl;//输出运行时间 return 0; }
注:GetTickCount函数返回从系统运行到现在所经历的时间(类型为DWORD),单位为ms,因为DWORD表示范围的限制,所以使用此种方法存在限制,即系统的运行时间的ms表示不能超出DWORD的表示范围。
第二种:使用clock()函数
#include<iostream> #include<time.h> using namespace std; int main() { clock_t start_time=clock(); { //被测试代码 } clock_t end_time=clock(); cout<< "Running time is: "<<static_cast<double>(end_time- start_time)/CLOCKS_PER_SEC*1000<<"ms"<<endl;//输出运行时间 return 0; }
clock_t,clock()定义于time.h中,clock()返回从程序运行时刻开始的时钟周期数,类型为long.CLOCKS_PER_SEC定义了每秒钟包含多少了时钟单元数,因为计算ms,所以*1000。
由上面分析可知,用clock()函数计算运行时间,表示范围一定大于GetTickCount()函数,所以,建议使用clock()函数。
1.获取系统时间 (使用CTime类 )
CString str; //获取系统时间 CTime tm; tm=CTime::GetCurrentTime(); str=tm.Format("现在时间是%Y年%m月%d日 %X"); MessageBox(str,NULL,MB_OK);
2: 得到系统时间日期 (使用GetLocalTime)
SYSTEMTIME st; CString strDate,strTime; GetLocalTime(&st); strDate.Format("%4d-%2d-%2d",st.wYear,st.wMonth,st.wDay); strTime.Format("%2d:%2d:%2d",st.wHour,st.wMinute,st.wSecond);
3.获取程序运行时间 (使用GetTickCount)
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); str=str1; t%=3600000; str1.Format("%d分",t/60000); str+=str1; t%=60000; str1.Format("%d秒",t/1000); str+=str1; AfxMessageBox(str);
相关文章推荐
- ASP获取当前系统日期和时间
- Android:获取系统当前日期时间
- 获取AX2009当前系统的日期和时间
- mysql中取系统当前时间,当前日期方便查询判定的代码
- VC++获取当前系统时间日期 GetSystemTime()函数的用法
- VC++获取当前系统时间日期 GetSystemTime()函数的用法
- java中获取当前系统时间,日期并格式化输出
- 网页中通过JavaScript 获取当前系统日期和时间
- c# 动态获取系统当前日期和时间
- Android获取当前系统日期和时间
- oracle中获取系统当前时间,启动时间以及运行时间
- js实时获取系统当前时间实例代码
- iOS开发-基础:获取系统当前日期,断点输出时间
- JAVA,jsp,oracle获取系统当前时间以及日期格式转换!
- JavaScript 获取当前系统日期和时间
- MS-SQL Server获取当前系统的日期和时间
- Js 获取当前日期时间及其它操作实现代码
- 【日期时间】批处理标准化获取当前系统日期
- js实时获取系统当前时间实例代码
- 获取当前系统时间计算后面的七天的日期和星期,本周,本月