zoukankan      html  css  js  c++  java
  • 使用.net Stopwatch class 来分析你的代码

     当我们在调试,优化我们的代码的时候,想知道某段代码的真正的执行时间,或者我们怀疑某段代码,或是某几段代码执行比较慢,

    需要得到具体的某段代码的具体执行时间的时候。有一个很好用的类Stopwatch。

    Stopwatch 类在 System.Diagnostics命名空间下。可以用来做分析.net代码块的基本工具。

    例如:

    复制代码
    System.Diagnostics.Stopwatch timerObj = new System.Diagnostics.Stopwatch();
    
    timerObj.Start();
    
    Decimal totalDec = 0;
    int limit = 1000000;
    for (int i = 0; i < limit; ++i) 
    {
    totalDec = totalDec + (Decimal)Math.Sqrt(i);
    }
    timerObj.Stop();
    Console.WriteLine(“Sum of square roots: {0}”,totalDec);
    Console.WriteLine(“Milliseconds elapsed : {0}”,timerObj.ElapsedMilliseconds);
    Console.WriteLine(“Time elapsed : {0}”, timerObj.Elapsed);
    复制代码

    输出结果:
    Sum of square roots : 666666166.45882210823608
    Milliseconds elapsed: 282
    Time elapsed : 00:00:00.2828692

    当你用Stopwatch 来调试你的时候,你可以使用 IDisposable 接口来自动关掉Stopwatch
    1.定义一个自定义的Stopwatch类,继承System.Diagnostics.Stopwatch 和 IDisposable

    复制代码
    class AutoStopwatchDemo : System.Diagnostics.Stopwatch, IDisposable
    {
    public AutoStopwatchDemo()
    {
    Start();
    }
    public void Dispose()
    {
    Stop();
    Console.WriteLine(“Elapsed : {0}”, this.Elapsed);
    }
    }
    复制代码

    2. 在你要调试的代码块里面使用

    复制代码
    using (new AutoStopwatchDemo())
    {
    Decimal totalObj2 = 0;
    int limitObj2 = 1000000;
    for (int i = 0; i < limit2; ++i)
    {
    totalObj2 = limitObj2 + (Decimal)Math.Sqrt(i);
    }
    }
    复制代码

    此外,Stopwatch除了有Start()和Stop()方法,还有 Reset() 方法

  • 相关阅读:
    深入理解JVM(二)--对象的创建
    深入理解JVM(一) -- 自动内存管理机制
    代理模式(Proxy)
    心知天气数据API 产品的高并发实践
    Jenkins 构建踩坑经历
    log4net SmtpAppender 踩坑总结
    从 ASP.NET Core 2.1 迁移到 2.2 踩坑总结
    在Windows上安装 Consul
    redis-desktop-manager 0.9.3 安装(最后一个免费版本)
    在Windows上安装Redis
  • 原文地址:https://www.cnblogs.com/zhangkeyu/p/6663850.html
Copyright © 2011-2022 走看看