C# 统计代码运行时长

2024-05-12 08:04

本文主要是介绍C# 统计代码运行时长,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

using System;
using System.Collections.Generic;
using System.Diagnostics;
using System.IO;
using System.Linq;
using System.Text;
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Forms;namespace Sci
{/// <summary>/// 统计代码运行时长(用于记录代码执行耗时信息)/// </summary>public class LogTime{/// <summary>/// 示例/// </summary>/// <param name="sender"></param>/// <param name="e"></param>public static void example(object sender, EventArgs e){LogTime.Start();// 待统计时长的代码...string timeStr = LogTime.CurrentStackTrace();MessageBox.Show(timeStr);LogTime.End("自定义注释信息");     // LogTime.End();}static Dictionary<string, long> timeDic = new Dictionary<string, long>();/// <summary>/// 记录log的开始时间/// </summary>/// <param name="tag"></param>/// <returns></returns>public static void Start(){string key = CurrentMethod(2) + System.Threading.Thread.CurrentThread.ManagedThreadId;  // 获取调用Start()函数的函数名timeDic.Add(key, DateTime.Now.Ticks);                                                   // 记录当前调用时间}/// <summary>/// 记录指定log的结束时间/// </summary>public static void End(string msg = ""){long curTime = DateTime.Now.Ticks;string key = CurrentMethod(2) + System.Threading.Thread.CurrentThread.ManagedThreadId;  // 获取调用End()函数的函数名if (timeDic.ContainsKey(key)){long preTime = timeDic[key];                                                        // 获取Start()函数的调用时间if (msg.Length > 0) msg = "(" + msg + ")";string info = " " + CurrentMethod(2) + msg + " -> 执行耗时: " + getTimeSpan(curTime, preTime);  // 生成耗时信息ThreadPool.QueueUserWorkItem((state) => { Write(info); });                          // 记录至log中timeDic.Remove(key);}}/// <summary>/// 获取调用当前函数的方法名(索引1),/// </summary>/// <returns></returns>public static string CurrentMethod(int index = 1){StackTrace stackTrace = new StackTrace();StackFrame stackFrame = stackTrace.GetFrame(index);return ToString(stackFrame, true);}/// <summary>/// 获取当前调用堆栈信息/// </summary>/// <returns></returns>public static string CurrentStackTrace(){return ToString(new StackTrace());}private static string ToString(StackTrace stackTrace, bool simple = false){StringBuilder sb = new StringBuilder();for (int i = 0; i < stackTrace.FrameCount; i++){StackFrame stackFrame = stackTrace.GetFrame(i);sb.AppendLine(ToString(stackFrame, simple));}return sb.ToString();}private static string ToString(StackFrame stackFrame, bool simple = false){if (simple) return stackFrame.GetMethod() + " ";else return stackFrame.GetFileName() + " -> " + stackFrame.GetMethod() + ",行号:" + stackFrame.GetFileLineNumber() + ",列号:" + stackFrame.GetFileColumnNumber();}static int[] unit = { 1000, 1000, 60, 60, 60, 24, 365 };static string[] unitName = { "微秒", "毫秒", "秒", "分", "时", "天", "年" };/// <summary>/// 获取耗时时长/// </summary>/// <param name="curTime"></param>/// <param name="preTime"></param>/// <returns></returns>private static string getTimeSpan(long curTime, long preTime){long tickSpan = (curTime - preTime) / 10;if (tickSpan < 0) tickSpan = -tickSpan;string timeStr = "";for (int i = 0; i < unit.Length; i++){int unitI = unit[i];if (tickSpan % unitI >= 0) timeStr = (tickSpan % unitI) + unitName[i] + timeStr;if (tickSpan > unitI) tickSpan = tickSpan / unitI;else break;}return timeStr;}/// <summary>/// 向TimeLog中添加信息/// </summary>/// <param name="info"></param>/// <param name="newLine"></param>/// <param name="time"></param>/// <returns></returns>public static bool Write(string info, bool newLine = true, bool time = true){try{string logPath = Application.StartupPath + "\\LogTime";if (!Directory.Exists(logPath)){Directory.CreateDirectory(logPath);}string threadId = System.Threading.Thread.CurrentThread.ManagedThreadId + "";logPath = logPath + "\\" + DateTime.Now.ToString("yyyyMMdd_HH") + ((DateTime.Now.Minute / 5 * 5) + "").PadLeft(2, '0') + "00_" + threadId + ".txt"; // 每5分钟,输出至一个log文件中,不同线程输出至不同文件中string data = info;if (time) data = "[" + DateTime.Now.ToString("HH:mm:ss") + "] " + data;if (newLine) data = "\r\n" + data;File.AppendAllText(logPath, data, Encoding.Unicode);return true;}catch (Exception){return false;}}}
}

这篇关于C# 统计代码运行时长的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/982060

相关文章

Pandas统计每行数据中的空值的方法示例

《Pandas统计每行数据中的空值的方法示例》处理缺失数据(NaN值)是一个非常常见的问题,本文主要介绍了Pandas统计每行数据中的空值的方法示例,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是空值?为什么要统计空值?准备工作创建示例数据统计每行空值数量进一步分析www.chinasem.cn处

C# foreach 循环中获取索引的实现方式

《C#foreach循环中获取索引的实现方式》:本文主要介绍C#foreach循环中获取索引的实现方式,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录一、手动维护索引变量二、LINQ Select + 元组解构三、扩展方法封装索引四、使用 for 循环替代

C# Where 泛型约束的实现

《C#Where泛型约束的实现》本文主要介绍了C#Where泛型约束的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录使用的对象约束分类where T : structwhere T : classwhere T : ne

C#实现将Excel表格转换为图片(JPG/ PNG)

《C#实现将Excel表格转换为图片(JPG/PNG)》Excel表格可能会因为不同设备或字体缺失等问题,导致格式错乱或数据显示异常,转换为图片后,能确保数据的排版等保持一致,下面我们看看如何使用C... 目录通过C# 转换Excel工作表到图片通过C# 转换指定单元格区域到图片知识扩展C# 将 Excel

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程

C#TextBox设置提示文本方式(SetHintText)

《C#TextBox设置提示文本方式(SetHintText)》:本文主要介绍C#TextBox设置提示文本方式(SetHintText),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录C#TextBox设置提示文本效果展示核心代码总结C#TextBox设置提示文本效果展示核心代

C#中DrawCurve的用法小结

《C#中DrawCurve的用法小结》本文主要介绍了C#中DrawCurve的用法小结,通常用于绘制一条平滑的曲线通过一系列给定的点,具有一定的参考价值,感兴趣的可以了解一下... 目录1. 如何使用 DrawCurve 方法(不带弯曲程度)2. 如何使用 DrawCurve 方法(带弯曲程度)3.使用Dr

Mysql如何将数据按照年月分组的统计

《Mysql如何将数据按照年月分组的统计》:本文主要介绍Mysql如何将数据按照年月分组的统计方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录mysql将数据按照年月分组的统计要的效果方案总结Mysql将数据按照年月分组的统计要的效果方案① 使用 DA

使用C#代码在PDF文档中添加、删除和替换图片

《使用C#代码在PDF文档中添加、删除和替换图片》在当今数字化文档处理场景中,动态操作PDF文档中的图像已成为企业级应用开发的核心需求之一,本文将介绍如何在.NET平台使用C#代码在PDF文档中添加、... 目录引言用C#添加图片到PDF文档用C#删除PDF文档中的图片用C#替换PDF文档中的图片引言在当

详解C#如何提取PDF文档中的图片

《详解C#如何提取PDF文档中的图片》提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使用,下面我们就来看看如何使用C#通过代码从PDF文档中提取图片吧... 当 PDF 文件中包含有价值的图片,如艺术画作、设计素材、报告图表等,提取图片可以将这些图像资源进行单独保存,方便后续在不同的项目中使