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

相关文章

hdu1496(用hash思想统计数目)

作为一个刚学hash的孩子,感觉这道题目很不错,灵活的运用的数组的下标。 解题步骤:如果用常规方法解,那么时间复杂度为O(n^4),肯定会超时,然后参考了网上的解题方法,将等式分成两个部分,a*x1^2+b*x2^2和c*x3^2+d*x4^2, 各自作为数组的下标,如果两部分相加为0,则满足等式; 代码如下: #include<iostream>#include<algorithm

2. c#从不同cs的文件调用函数

1.文件目录如下: 2. Program.cs文件的主函数如下 using System;using System.Collections.Generic;using System.Linq;using System.Threading.Tasks;using System.Windows.Forms;namespace datasAnalysis{internal static

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M

flume系列之:查看flume系统日志、查看统计flume日志类型、查看flume日志

遍历指定目录下多个文件查找指定内容 服务器系统日志会记录flume相关日志 cat /var/log/messages |grep -i oom 查找系统日志中关于flume的指定日志 import osdef search_string_in_files(directory, search_string):count = 0

hdu4267区间统计

题意:给一些数,有两种操作,一种是在[a,b] 区间内,对(i - a)% k == 0 的加value,另一种操作是询问某个位置的值。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import

hdu4417区间统计

给你一个数列{An},然后有m次查询,每次查询一段区间 [l,r] <= h 的值的个数。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamRead

hdu3333区间统计

题目大意:求一个区间内不重复数字的和,例如1 1 1 3,区间[1,4]的和为4。 import java.io.BufferedInputStream;import java.io.BufferedReader;import java.io.IOException;import java.io.InputStream;import java.io.InputStreamReader;

实例:如何统计当前主机的连接状态和连接数

统计当前主机的连接状态和连接数 在 Linux 中,可使用 ss 命令来查看主机的网络连接状态。以下是统计当前主机连接状态和连接主机数量的具体操作。 1. 统计当前主机的连接状态 使用 ss 命令结合 grep、cut、sort 和 uniq 命令来统计当前主机的 TCP 连接状态。 ss -nta | grep -v '^State' | cut -d " " -f 1 | sort |

C# dateTimePicker 显示年月日,时分秒

dateTimePicker默认只显示日期,如果需要显示年月日,时分秒,只需要以下两步: 1.dateTimePicker1.Format = DateTimePickerFormat.Time 2.dateTimePicker1.CustomFormat = yyyy-MM-dd HH:mm:ss Tips:  a. dateTimePicker1.ShowUpDown = t