C# 精准计时之 QueryPerformanceCounter QueryPerformanceFrequency用法

C# 用法:

    public static class QueryPerformanceMethd
    {
        [DllImport("kernel32.dll")]
      public  extern static short QueryPerformanceCounter(ref long x);


        [DllImport("kernel32.dll")]
        public extern static short QueryPerformanceFrequency(ref long x);
    }

 

    static void Main(string[] args)
        {
            long stop_Value = 0; long start_Value = 0; long freq = 0; QueryPerformanceMethd.QueryPerformanceFrequency(ref freq); QueryPerformanceMethd.QueryPerformanceCounter(ref start_Value); //Fun() 需要计时方法 QueryPerformanceMethd.QueryPerformanceCounter(ref stop_Value); double time = (double)(stop_Value - start_Value) / (double)(freq); Console.WriteLine(time);//单位S  Console.ReadLine(); } 

计算所得time即为fun()方法所消耗时间。

 

 

C++中QueryPerformanceCounter  QueryPerformanceFrequency的用法

#include "stdafx.h"
#include "windows.h"


void main()
{
    LARGE_INTEGER nFreq;
    LARGE_INTEGER nBeginTime;
    LARGE_INTEGER nEndTime;
    double time;
    QueryPerformanceFrequency(&nFreq);
    QueryPerformanceCounter(&nBeginTime);
    Sleep(1000);
    QueryPerformanceCounter(&nEndTime);
    time = (double)(nEndTime.QuadPart - nBeginTime.QuadPart) / (double)nFreq.QuadPart;
    printf("%f\n", time);
    system("Pause");
}

计算Sleep(1000)所消耗的精确时间,并非精确的1s

 

转载于:https://www.cnblogs.com/Van-Bumblebee/p/5483432.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值