2014-12-15 22:58:49 +08:00
|
|
|
|
using System;
|
2015-11-02 00:04:05 +00:00
|
|
|
|
using System.Collections.Generic;
|
2014-12-15 22:58:49 +08:00
|
|
|
|
using System.Diagnostics;
|
2015-11-02 00:04:05 +00:00
|
|
|
|
using Wox.Plugin;
|
2014-12-15 22:58:49 +08:00
|
|
|
|
|
|
|
|
|
|
namespace Wox.Infrastructure
|
|
|
|
|
|
{
|
|
|
|
|
|
public class Timeit : IDisposable
|
|
|
|
|
|
{
|
2015-11-02 00:04:05 +00:00
|
|
|
|
private readonly Stopwatch _stopwatch = new Stopwatch();
|
|
|
|
|
|
private readonly string _name;
|
2014-12-15 22:58:49 +08:00
|
|
|
|
|
|
|
|
|
|
public Timeit(string name)
|
|
|
|
|
|
{
|
2015-11-02 00:04:05 +00:00
|
|
|
|
_name = name;
|
|
|
|
|
|
_stopwatch.Start();
|
2014-12-15 22:58:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
|
2015-11-02 00:04:05 +00:00
|
|
|
|
public long Current
|
|
|
|
|
|
{
|
|
|
|
|
|
get
|
|
|
|
|
|
{
|
|
|
|
|
|
_stopwatch.Stop();
|
|
|
|
|
|
long seconds = _stopwatch.ElapsedMilliseconds;
|
|
|
|
|
|
_stopwatch.Start();
|
|
|
|
|
|
Debug.WriteLine(_name + ":" + _stopwatch.ElapsedMilliseconds + "ms");
|
|
|
|
|
|
return seconds;
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
2014-12-15 22:58:49 +08:00
|
|
|
|
public void Dispose()
|
|
|
|
|
|
{
|
2015-11-02 00:04:05 +00:00
|
|
|
|
_stopwatch.Stop();
|
|
|
|
|
|
Debug.WriteLine(_name + ":" + _stopwatch.ElapsedMilliseconds + "ms");
|
2014-12-15 22:58:49 +08:00
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|