码迷,mamicode.com
首页 > 其他好文 > 详细

GetTickCount()函数的陷阱!

时间:2014-10-23 22:41:32      阅读:183      评论:0      收藏:0      [点我收藏+]

标签:windows c++

开发中经常用GetTickCount()函数来进行间隔时间的判断,如判断某一段代码执行花了多少时间等,使用比较方便。 但是只针对平常的一些测试。最近开发一个服务程序时,也在代码中用GetTickCount()来进行判断,大体格式如下:

DWORD dwBegin = 0;

void Thread_Run(void)
{	
	while(TRUE)
	{
		DWORD dwNow = GetTickCount();
		if (dwNow - dwBegin > 30) //second
		{
			....//
			dwBegin = dwNow;
		}
	}
}

问题来了,GetTickCount()返回的是DWORD类型,返回的值代表程序从启动到现在走过的时间。DWORD类型的最大值为4294967295,折算成天是49.7,也就是说当服务程序连续跑了50天之后,再调用GetTickCount()的时候就会发生溢出。所以服务程序尽量不要用GetTickCount()。如果要判断间隔时间可以用1970年以来的秒数差来计算。


GetTickCount()函数的陷阱!

标签:windows c++

原文地址:http://blog.csdn.net/hs_jiephe/article/details/40405327

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!