C/C++中如何精确计时
2013-09-21 23:26
295 查看
/article/1515921.html
给程序计时对于程序员来说实在是太重要了,在windows上的那个clock()实在是不够精确,精度只有10ms,真让人难过。研究了下windows下使用C、C++计时的函数,给大家分享下。 主要就是两个函数的使用。我先把一段可以运行的代码贴出来,然后讲讲这两个函数。
#include <windows.h>
#include <stdio.h>
int main(int argc, char **argv)
{
LARGE_INTEGER freq;
LARGE_INTEGER start_t, stop_t;
double exe_time;
QueryPerformanceFrequency(&freq);
fprintf(stdout, "The frequency of your pc is %d.\n", freq.QuadPart);
QueryPerformanceCounter(&start_t);
Sleep(1000);
QueryPerformanceCounter(&stop_t);
exe_time = 1e3*(stop_t.QuadPart-start_t.QuadPart)/freq.QuadPart;
fprintf(stdout, "Your program executed time is %fms.\n", exe_time);
getchar();
return 0;
}
1、LARGE_INTEGER在微软的编译器中实际上是一个union,它的定义如下: typedef union _LARGE_INTEGER
{
struct
{
DWORD LowPart;
LONG HighPart;
};
struct
{
DWORD LowPart;
LONG HighPart;
} u;
LONGLONG QuadPart;
} LARGE_INTEGER, *PLARGE_INTEGER;
如果你使用的编译器支持64位整数,那么可以使用QuadPart来引用变量的值。如果你的编译器不支持64位整数,那么可以使用LowPart和HighPart来引用64位整数的低32位和高32位。
2、QueryPerformanceFrequncy(LARGE_INTEGER *freq)
它用于获得你的机器一秒钟执行多少次,就是你的时钟周期。
3、QueryPerformanceCounter(LARGE_INTEGER *lpPerformanceCount)
它获得的是CPU从开机以来执行的时钟周期数。
O啦。。。。好好用用它吧。
给程序计时对于程序员来说实在是太重要了,在windows上的那个clock()实在是不够精确,精度只有10ms,真让人难过。研究了下windows下使用C、C++计时的函数,给大家分享下。 主要就是两个函数的使用。我先把一段可以运行的代码贴出来,然后讲讲这两个函数。
#include <windows.h>
#include <stdio.h>
int main(int argc, char **argv)
{
LARGE_INTEGER freq;
LARGE_INTEGER start_t, stop_t;
double exe_time;
QueryPerformanceFrequency(&freq);
fprintf(stdout, "The frequency of your pc is %d.\n", freq.QuadPart);
QueryPerformanceCounter(&start_t);
Sleep(1000);
QueryPerformanceCounter(&stop_t);
exe_time = 1e3*(stop_t.QuadPart-start_t.QuadPart)/freq.QuadPart;
fprintf(stdout, "Your program executed time is %fms.\n", exe_time);
getchar();
return 0;
}
1、LARGE_INTEGER在微软的编译器中实际上是一个union,它的定义如下: typedef union _LARGE_INTEGER
{
struct
{
DWORD LowPart;
LONG HighPart;
};
struct
{
DWORD LowPart;
LONG HighPart;
} u;
LONGLONG QuadPart;
} LARGE_INTEGER, *PLARGE_INTEGER;
如果你使用的编译器支持64位整数,那么可以使用QuadPart来引用变量的值。如果你的编译器不支持64位整数,那么可以使用LowPart和HighPart来引用64位整数的低32位和高32位。
2、QueryPerformanceFrequncy(LARGE_INTEGER *freq)
它用于获得你的机器一秒钟执行多少次,就是你的时钟周期。
3、QueryPerformanceCounter(LARGE_INTEGER *lpPerformanceCount)
它获得的是CPU从开机以来执行的时钟周期数。
O啦。。。。好好用用它吧。
相关文章推荐
- C/C++中如何精确计时
- C/C++中如何精确计时
- C/C++中如何精确计时
- C/C++中如何精确计时
- C/C++中如何精确计时
- c++实现精确计时
- C++ 程序精确计时
- [C++] 利用 C++ Builder 进行精确计时
- 计时精度到底毫秒级别或者更高 如何使用C#制作一个精确计时器
- 如何实现程序的精确计时
- C++ 精确计时
- windows下的C/C++精确计时
- Windows下用C/C++精确到微秒的计时方法
- C/C++如何以秒计时程序运行时间
- c++实现精确计时
- C++中精确计时的方法
- 综合项目之闪讯破解(五)之 如何用C#调用C++编写的Dll
- 教你如何用C++快速生成1000万个随机数
- 如何判断一段程序是由C 编译程序还是由C++编译程序编译的
- 高进度计时,精确到0.001秒,且不受任何干扰!