DWORD GetTickCount(void);
转载自https://blog.csdn.net/linjcai/article/details/81206143
1) 定义
For Release configurations, this function returns the number of milliseconds since the device booted, excluding any time that the system was suspended. GetTickCount starts at 0 on boot and then counts up from there.
在Release版本中,该函数从0开始计时,返回自设备启动后的毫秒数(不含系统暂停时间)。
For Debug configurations, 180 seconds is subtracted from the the number of milliseconds since the device booted. This allows code that uses GetTickCount to be easily tested for correct overflow handling.
在Debug版本中,设备启动后便从计时器中减去180秒。这样方便测试使用该函数的代码的正确溢出处理。
Return Values
The number of milliseconds indicates success.
返回值:如正确,返回毫秒数。
Header: Winbase.h.
Link Library: Coredll.lib.
2) 应用
用来计算某个操作所使用的时间:
Start: = GetTickCount; ... // 执行耗时的操作 Stop: = GetTickCount; TimeUsed: = (Stop - Start) / 1000 ; // 使用了xxx秒
用来定时:
void main() { DWORD dwLast; DWORD dwCurrent; DWORD dwInterval = 1000; dwLast = GetTickCount(); int i = 0; while(true) { dwCurrent = GetTickCount(); if( dwCurrent - dwLast < dwInterval ) continue; //your code to be executed when interval is elapsed printf("dwLast,dwCurrent,diff:%d,%d,%d ",dwLast,dwCurrent,dwCurrent-dwLast); //your code to determine when to break if( i > 10 ) break; i++; dwLast = dwCurrent; printf("Time is up!"); break; } getchar(); return; }
对于一般的实时控制,使用GetTickCount()函数就可以满足精度要求,但要进一步提高计时精度,就要采用QueryPerformanceFrequency()函数和QueryPerformanceCounter()函数。这两个函数是VC提供的仅供Windows 9X使用的高精度时间函数,并要求计算机从硬件上支持高精度计时器。