博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
.NET v2.0 下的高精度计数器 —— Stopwatch [.NET v2.0, C#]
阅读量:6760 次
发布时间:2019-06-26

本文共 2523 字,大约阅读时间需要 8 分钟。

.NET v2.0 下的高精度计数器 —— Stopwatch [.NET v2.0, C#]

 

Written by Allen Lee

 

无论你是搞技术研究还是搞项目开发,高精度的时间测量在很多场合下都是必需的。 在其提到了一个 QueryPerfCounter,它对目前还在使用 Microsoft .NET Framework v1.1 的开发人员来说的确是一个好帮手。但若你已经用上了 Microsoft .NET Framework v2.0,那么 Stopwatch 将会成为你进行高精度时间测量的不二选择。

 

1. 测试 Stopwatch

这里,我借用一下 xiaotie 在《dotnet下时间精度测量》的测试代码,并给出对应的运行结果:

None.gif
// Code #01
None.gif
None.gif
static
 
void
 Test1()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif
{
InBlock.gif    Stopwatch sw = 
new Stopwatch();
InBlock.gif    sw.Start();
InBlock.gif    sw.Stop();
InBlock.gif    Console.WriteLine("Stopwatch 时间精度:{0}ms", sw.ElapsedMilliseconds);
ExpandedBlockEnd.gif}
None.gif
None.gif
// Output:
None.gif//
None.gif// Stopwatch 时间精度:0ms
None.gif
None.gif
None.gif
static
 
void
 Test2()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif
{
InBlock.gif    Stopwatch sw = 
new Stopwatch();
InBlock.gif
InBlock.gif    
int loop = 10000;
InBlock.gif    
int exCount = 0;
InBlock.gif
InBlock.gif    
for (int i = 0; i ExpandedSubBlockStart.gifContractedSubBlock.gif    dot.gif{
InBlock.gif        sw.Reset();
InBlock.gif        sw.Start();
InBlock.gif        sw.Stop();
InBlock.gif        
if (sw.ElapsedMilliseconds != 0)
ExpandedSubBlockStart.gifContractedSubBlock.gif        
dot.gif{
InBlock.gif            exCount++;
InBlock.gif            Console.WriteLine("Stopwatch 时间精读异常:{0}ms", sw.ElapsedMilliseconds);
ExpandedSubBlockEnd.gif        }
ExpandedSubBlockEnd.gif    }
InBlock.gif
InBlock.gif    Console.WriteLine("共进行{0}次 Stopwatch 的时间精度测试", loop);
InBlock.gif    Console.WriteLine("其中{0}次 Stopwatch 的时间精度异常", exCount);
InBlock.gif    Console.WriteLine("时间校准有效性{0}%", 100 - (100.0 * exCount) / loop);
ExpandedBlockEnd.gif}
None.gif
None.gif
// Output:
None.gif//
None.gif// 共进行10000次 Stopwatch 的时间精度测试
None.gif// 其中0次 Stopwatch 的时间精度异常
None.gif// 时间校准有效性100%
None.gif
None.gif
None.gif
static
 
void
 Test3()
ExpandedBlockStart.gifContractedBlock.gif
dot.gif
{
InBlock.gif    Stopwatch sw = 
new Stopwatch();
InBlock.gif
InBlock.gif    
for (int i = 0; i ExpandedSubBlockStart.gifContractedSubBlock.gif    dot.gif{
InBlock.gif        sw.Reset();
InBlock.gif        sw.Start();
InBlock.gif        sw.Stop();
InBlock.gif        Console.WriteLine("Stopwatch 时间精度:{0}ms", sw.ElapsedMilliseconds);
InBlock.gif
InBlock.gif        sw.Reset();
InBlock.gif        sw.Start();
InBlock.gif        
int j = 0;
InBlock.gif        
for (j = 0; j ExpandedSubBlockStart.gifContractedSubBlock.gif        dot.gif{
InBlock.gif            
int l;
ExpandedSubBlockEnd.gif        }
InBlock.gif        sw.Stop();
InBlock.gif        Console.WriteLine("第{0}次循环,耗时{1}ms", i, sw.ElapsedMilliseconds);
InBlock.gif
InBlock.gif        Console.WriteLine();
ExpandedSubBlockEnd.gif    }
ExpandedBlockEnd.gif}
None.gif
None.gif
// Partial output:
None.gif//
None.gif// Stopwatch 时间精度:0ms
None.gif// 第10次循环,耗时0ms
None.gif//
None.gif// Stopwatch 时间精度:0ms
None.gif// 第12次循环,耗时0ms
None.gif//
None.gif// Stopwatch 时间精度:0ms
None.gif// 第16次循环,耗时0ms

从测试结果中可以看到,Stopwatch 绝对能够满足挑剔的你!怎么样?手痒了吗?

 

2. 应用 Stopwatch

Stopwatch 位于 System.Diagnostics 命名空间中,它的使用方法非常简单,只要你会用一般的计时器,你就会使用它。

2.1 创建实例

你可以通过 new 或者 Stopwatch.StartNew() 来创建一个 Stopwatch 实例:

None.gif
// Code #02
None.gif
None.gifStopwatch sw1 = 
new
 Stopwatch();
None.gifStopwatch sw2 = Stopwatch.StartNew();

使用 StartNew() 会创建一个 Stopwatch 实例并马上开始计时,即等效于如下代码:

None.gif
// Code #03
None.gif
None.gifStopwatch sw2 = 
new
 Stopwatch();
None.gifsw2.Start();

2.2 测量时间

None.gif
// Code #04
None.gif
None.gifsw1.Start();
None.gif
// Do something heredot.gif
None.gif
sw2.Stop();
None.gif
long
 elaspsedMilliseconds = sw1.ElaspedMilliseconds;

2.3 应用示例

微软官方提供了一系列示范程序用于演示 Visual Studio 2005,其中 Basic Class Library 部分带有一个 Stopwatch 的 Windows Forms 示例程序,你可以到 下载示例代码。

 

3. 深入 Stopwatch

Stopwatch 内部也调用了 QueryPerformanceCounter() 和 QueryPerformanceFrequency() 两个函数,与 QueryPerfCounter 不同的是,当 Stopwatch 检测到当前的系统和硬件不支持高精度的计数器时,它将转用我们所熟悉的 DateTime 做法。

Stopwatch 在其静态构造器中调用 QueryPerformanceFrequency(),透过该函数的返回值判断当前的系统和硬件是否支持高精度的计数器,并设置 IsHighResolution 属性的值。Stopwatch 内部用于计算时间间隔的主要方法都会根据 IsHighResolution 的值来选择合适的计算方法。有兴趣的话,你可以使用 探究一下 Stopwatch 的内部。

转载地址:http://lkbeo.baihongyu.com/

你可能感兴趣的文章
菜鸟学Java(一)——Ajax异步检查用户名是否存在
查看>>
【Javascript】类,封装性 -- 1
查看>>
Mono for Android安装配置破解
查看>>
uploadfy 常见问题收集
查看>>
WPF----数据绑定
查看>>
子类化GetOpenFileName/GetSaveFileName, 以及钩子函数OFNHookProc的使用的简要说明
查看>>
C语言中判断int,long型等变量是否赋值的方法
查看>>
leetcode -- Longest Valid Parentheses
查看>>
中位数与第K小元素
查看>>
详解JAVA输出Hello World
查看>>
概率问题随笔
查看>>
关于在堆中创建字符串对象的疑惑
查看>>
poj1077(康托展开+bfs+记忆路径)
查看>>
hibernate 树状映射
查看>>
值得 Web 开发人员收藏的20个 HTML5 实例教程
查看>>
经典网页设计:无缝过渡的响应式设计案例
查看>>
ASP.NET MVC 多语言方案
查看>>
移动设备、手机浏览器Javascript滑动事件代码
查看>>
linux,__attribute__用法
查看>>
LinqToXML~读XML文件续
查看>>