C#添加测量运转时刻

应用范围

拔取模块化开发,每种模块都有开始化成效,早先化功效只怕包罗:加载配置表,初始化事件,开端化设置

那就是说只要想测量每种模块的Init时间吧?Net框架已经提供了测量运维的点子

C#,System.Diagnostics

System.Diagnostics
命名空间包蕴具有以下功效的门类:能让您与系统经过、事件日志和属性计数器之间进行互相。

子命名空间包蕴具有以下作用的品类:与代码分析工具举行相互,帮忙签订,扩大对应用程序监控和检测的布置性时支持,使用
Windows 事件跟踪 (ETW)
跟踪子系统来记录事件数量,在事变日志中展开读取和写入,收集性能数据,以及读取和写入调试符号音讯。

使用方法

public class GameSetting
{
    //初始化
    public void Init()
    {
        PerformanceHelper.AddWatch("Init Gamesetting :{0}s",LoadConfig);
    }

    public void LoadConfig()
    {
        //TODO 加载配置表
    }
}

System.Diagnostics.Stopwatch

提供一组方法和性质,可用于规范地测量运营时刻。

MSDN:https://msdn.microsoft.com/zh-cn/library/system.diagnostics.stopwatch(v=vs.110).aspx

 

Help组件

public class PerformanceHelper
{
    // 添加性能观察
    public static void AddWatch(Action del)
    {
        AddWatch("执行耗费时间: {0}s", del);
    }
    public static void AddWatch(string outputStr, Action del)
    {
        if (Debug.isDebugBuild)//判断是否检测运行时间
        {
            System.Diagnostics.Stopwatch stopwatch = new System.Diagnostics.Stopwatch();
            stopwatch.Start(); //  开始监视代码运行时间

            if (del != null)
            {
                del();
            }

            stopwatch.Stop(); //  停止监视
            TimeSpan timespan = stopwatch.Elapsed; //  获取当前实例测量得出的总时间
            double millseconds = timespan.TotalMilliseconds;//总毫秒数
            decimal seconds = (decimal)millseconds / 1000m;
            Debug.Log(string.Format(outputStr, seconds.ToString("F7"))); // 7位精度
        }
        else
        {
            if (del != null)
            {
                del();
            }
        }
    }
}

 

相关文章