C# Stopwatch实现计算代码运行时间
public class CheckPointCodeTime
{
Stopwatch _sw = Stopwatch.StartNew();
Queue
double _sum = 0;
int _maxAvgCount = 0;
///
/// 当前耗时时,单位秒
///
public double Time { get; set; }
///
/// 平均耗时时,单位秒
///
public double Average { get; set; }
///
/// 构造方法
///
/// 计算平均总共个数
public CheckPointCodeTime(int maxAvgCount = 60)
{
_maxAvgCount = maxAvgCount;
}
///
/// 检查点
///
/// 是否打印
/// 打印的标签
public void Check(bool isPrint = true, string printLable = "")
{
if (!_sw.IsRunning)
{
_sw.Restart();
return;
}
_sw.Stop();
Time = _sw.ElapsedMilliseconds / 1000.0;
_times.Enqueue(Time);
_sum += Time;
Average = _sum / _times.Count;
Console.WriteLine(printLable + "当前耗时(s):" + Time + " 平均耗时(s):" + Average);
if (_times.Count >= _maxAvgCount)
{
_sum -= _times.Dequeue();
}
_sw.Restart();
}
}
- .NET Core系列之MemoryCache 初识
- 007手机一键Root(安机网一键Root) v3.0 官方最新版 一键ROOT您的Android手机
- 12306密码被盗了怎么办?12306密码外泄解决方法
- 12个字的qq网名
- 150M迷你型无线路由器怎么设置?
- 192.168.1.1打不开怎么办?路由器192.168.1.1打不开的原因以及解决办法
- 2011年电子报合订本 电子报 编辑部 中文 PDF版 [84M]
- 2015年1月15日小米新旗舰发布会现场图文直播
- 2016.3.1vivo Xplay5新品发布会现场视频直播 优酷直播
- 2016华为P9发布会视频直播地址 4月15日华为P9国行发布会直播