(转)windows平台时间函数性能比较QueryPerformanceCounter,GetTickCount,ftime,time,GetLocalTime,GetSystemTimeAsFile...

执行 10000000 次, 耗时 2258,369 微秒     QueryPerformanceCounter

 

执行 10000000 次, 耗时 26,347 微秒    GetTickCount

 

 

执行 10000000 次, 耗时 242,879 微秒     time()

c的时间函数 time(time_t) 大概比GetSystemTimeAsFileTime慢6倍,比_ftime 快6倍

 

执行 10000000 次, 耗时 1310,066 微秒   _ftime

 

执行 10000000 次, 耗时 1722,125 微秒  GetLocalTime

 

执行 10000000 次, 耗时 39,131 微秒  GetSystemTimeAsFileTime

 

GetLocalTime耗时等于  = GetSystemTimeAsFileTime 耗时+  FileTimeToSystemTime 的耗时

------------

可以看到精度越高性能越差

GetTickCount  精度1毫秒  >  GetLocalTime  精度100纳秒 (0.1 微秒)  >  QueryPerformanceCounter  (搞不懂这个怎么这么差)

 

 

如果仅仅为了计算时间偏差,可以使用 GetSystemTimeAsFileTime,这个精度可以达到100纳秒,

msdn有个介绍。

http://msdn.microsoft.com/ZH-CN/library/windows/desktop/ms724284(v=vs.85).aspx

Contains a 64-bit value representing the number of 100-nanosecond intervals since January 1, 1601 (UTC).

 

It is not recommended that you add and subtract values from the FILETIME structure to obtain relative times. Instead, you should copy the low- and high-order parts of the file time to a ULARGE_INTEGER structure, perform 64-bit arithmetic on the QuadPart member, and copy the LowPart and HighPart members into the FILETIME structure.

Do not cast a pointer to a FILETIME structure to either a ULARGE_INTEGER* or __int64* value because it can cause alignment faults on 64-bit Windows.

 

测试代码如下

 

 

#include <iomanip>
#include <fstream>
#include <iostream>
#include <map>
#include <sstream>
#include <list>
#include <vector>
   
   
#include <stdlib.h>
#include <stdint.h>
#include <stdio.h>
#include <sys/types.h>
#include <sys/timeb.h>
#include <time.h>
#include <Windows.h>
   
   
#include "Trace.h"
   
using  namespace std;
   
   
   
  int  main (int, char**)
{
    
  LARGE_INTEGER freq, t0, t1;
  QueryPerformanceFrequency(&freq);
  size_t  number = 10000000;
      
    
    
  int  total_counter = 0;
  //LARGE_INTEGER t3;
     
  //struct timeb timebuffer;
  SYSTEMTIME lt; 
  FILETIME SystemTimeAsFileTime;
    
  QueryPerformanceCounter(&t0);
  for  (int i=0; i< number; i++) {
     //QueryPerformanceCounter(&t3);
     //total_counter  += t3.LowPart;
      //total_counter += GetTickCount();
 
      //ftime(&timebuffer);
      //total_counter += timebuffer.time;
    
     //GetLocalTime(&lt); 
     //total_counter += lt.wMilliseconds;
    
    // total_counter += _time32(NULL);   time(NULL)
    
      GetSystemTimeAsFileTime(&SystemTimeAsFileTime);
      FileTimeToSystemTime(&SystemTimeAsFileTime,&lt);
      total_counter += lt.wMilliseconds;
  }
  QueryPerformanceCounter(&t1);
    
  int  time = (((t1.QuadPart-t0.QuadPart)*1000000)/freq.QuadPart);
  std::cout  <<  "执行 "  << number <<" 次, 耗时 " << time <<  " 微秒" << std::endl;
     
  std::cout << total_counter;
  int  a;
  cin >> a;
  return  0;
}
 
 转自:http://gmd20.blog.163.com/blog/static/168439232012113111759514/

转载于:https://www.cnblogs.com/lihaiping/p/4194984.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值