获取运行时间GetSystemTimeAsFileTime QueryPerformanceCounter

本文介绍了在获取运行时间时,如何从使用QueryPerformanceCounter转向使用GetSystemTimeAsFileTime的原因及方法。由于QueryPerformanceCounter的系统调用时间较长,作者建议使用GetSystemTimeAsFileTime作为更高效的替代方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

之前一直用 QueryPerformanceFrequency , QueryPerformanceCounter发现系统调用时间比较长.

改用 GetSystemTimeAsFileTime

 

新的:

#include <Windows.h>

class TimeStamp
{
    static FILETIME __startFileTime,__endFileTime;
    static ULARGE_INTEGER __startTime , __endTime;

public:
    static void start() {
        GetSystemTimeAsFileTime(&__startFileTime);
        __startTime.LowPart = __startFileTime.dwLowDateTime;
        __startTime.HighPart = __startFileTime.dwHighDateTime;
    }
    static unsigned __int64 elapsed() {
        GetSystemTimeAsFileTime(&__endFileTime);
        __endTime.LowPart = __endFileTime.dwLowDateTime;
        __endTime.HighPart = __endFileTime.dwHighDateTime;
        return (__endTime.QuadPart - __startTime.QuadPart) / 10000; // ms

    }
};
ULARGE_INTEGER TimeStamp::__endTime = {0};
ULARGE_INTEGER TimeStamp::__startTime = {0};
FILETIME TimeStamp::__endFileTime = {0};
FILETIME TimeSt
Creating Windows CreateMDIWindow CreateWindow CreateWindowEx RegisterClass RegisterClassEx UnregisterClass Message Processing BroadcastSystemMessage CallNextHookEx CallWindowProc DefFrameProc DefMDIChildProc DefWindowProc DispatchMessage GetMessage GetMessageExtraInfo GetMessagePos GetMessageTime GetQueueStatus InSendMessage PeekMessage PostMessage PostQuitMessage PostThreadMessage RegisterWindowMessage ReplyMessage SendMessage SendMessageCallback SendMessageTimeout SendNotifyMessage SetMessageExtraInfo SetWindowsHookEx TranslateMessage UnhookWindowsHookEx WaitMessage Window Information AnyPopup ChildWindowFromPoint ChildWindowFromPointEx EnableWindow EnumChildWindows EnumPropsEx EnumThreadWindows EnumWindows FindWindow FindWindowEx GetClassInfoEx GetClassLong GetClassName GetClientRect GetDesktopWindow GetFocus GetForegroundWindow GetNextWindow GetParent GetProp GetTopWindow GetWindow GetWindowLong GetWindowRect GetWindowText GetWindowTextLength IsChild IsIconic IsWindow IsWindowEnabled IsWindowUnicode IsWindowVisible IsZoomed RemoveProp SetActiveWindow SetClassLong SetFocus SetForegroundWindow SetParent SetProp SetWindowLong SetWindowText WindowFromPoint Processes and Threads CreateEvent CreateMutex CreateProcess CreateSemaphore CreateThread DeleteCriticalSection DuplicateHandle EnterCriticalSection ExitProcess ExitThread GetCurrentProcess GetCurrentProcessId GetCurrentThread GetCurrentThreadId GetExitCodeProcess GetExitCodeThread GetPriorityClass GetThreadPriority GetWindowThreadProcessId InitializeCriticalSection InterlockedDecrement InterlockedExchange InterlockedIncrement LeaveCriticalSection OpenEvent OpenMutex OpenProcess OpenSemaphore PulseEvent ReleaseMutex ReleaseSemaphore ResetEvent ResumeThread SetEvent SetPr
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值