我想以毫秒为单位测量我启动应用程序和另一个时间之间的时间,例如 16:00 点。做这个的最好方式是什么?
我环顾了“时钟”功能,但这不是我需要的。
操作系统:Win NT及以上
查找POSIX 系统的gettimeofday和 Windows 的timeGetTime。
编辑:似乎 OP 要求代码将当前时间/日期与另一个时间/日期进行比较。以下代码段演示了如何在 Windows 上获取当前日期和时间:
#include <Windows.h> #include <stdio.h> void main() { SYSTEMTIME st; GetSystemTime(&st); printf("Year:%d\nMonth:%d\nDate:%d\nHour:%d\nMin:%d\nSecond:%d\n" ,st.wYear,st.wMonth,st.wDay,st.wHour,st.wMinute,st.wSecond); }
以下是计算两个 SYSTEMTIME 对象之间差异的方法:
#include <windows.h> #include <iostream> // Return time difference in units of 100 us. _int64 Delta(const SYSTEMTIME st1, const SYSTEMTIME st2) { union timeunion { FILETIME fileTime; ULARGE_INTEGER ul; } ; timeunion ft1; timeunion ft2; SystemTimeToFileTime(&st1, &ft1.fileTime); SystemTimeToFileTime(&st2, &ft2.fileTime); return ft2.ul.QuadPart - ft1.ul.QuadPart; } int main() { SYSTEMTIME t1 = {0}, t2 = {0}; t1.wDay = 10; t1.wMonth = 4; t1.wYear = 2009; t2.wDay = 12; t2.wMonth = 4; t2.wYear = 2009; _int64 i = Delta(t1, t2); std::cout << "times are " << i / 10000000 << " seconds apart\n"; return 0; }
这两个示例应该为您提供执行所需操作的工具。
如果您使用的是 POSIX 系统,则可以使用gettimeofday(3)
:
struct timeval start, end;
gettimeofday(&start, NULL);
...
gettimeofday(&end, NULL);
// Watch out for overflow!
int delta_milliseconds = 1000 * (end.tv_sec - start.tv_sec) + (end.tv_usec - start.tv_usec)/1000;
如果您使用的是 Windows,则可以使用GetTickCount
:
DWORD start, end;
start = GetTickCount();
...
end = GetTickCount();
int delta_milliseconds = end - start;
但是但要知道,它GetTickCount
只有大约 10-16 毫秒的分辨率。如果您需要更高的精度,请使用QueryPerformanceCounter
andQueryPerformanceFrequency
代替:
// Error-checking omitted for expository purposes
LARGE_INTEGER freq, start, end;
QueryPerformanceFrequency(&freq);
QueryPerformanceCounter(&start);
...
QueryPerformanceCounter(&end);
double delta_milliseconds = (double)(end.QuadPart - start.QuadPart) / freq.QuadPart * 1000.0;