首页 > 极客资料 博客日记
一个.NET开源、轻量级的运行耗时统计库 - MethodTimer
2024-11-06 09:00:04极客资料围观16次
本篇文章分享一个.NET开源、轻量级的运行耗时统计库 - MethodTimer,对你有帮助的话记得收藏一下,看极客之家收获更多编程知识
前言
在.NET开发中,为了准确统计对应方法的执行时间,我们最常用的方式是手动使用 Stopwatch 来显式编写计时逻辑,但是假如你需要大量的使用 Stopwatch 来进行耗时统计的话不利于保持代码的整洁和增加代码的维护成本。
项目介绍
MethodTimer是一个.NET开源、免费(MIT License)、轻量级的运行耗时统计库,用于在编译时自动向指定方法注入计时代码,无需手动编写繁琐的计时逻辑。
创建控制台应用
创建名为:MethodTimerExercise
的控制台应用。
安装NuGet
命令安装
PM> Install-Package Fody
PM> Install-Package MethodTimer.Fody
NuGet包管理器安装
搜索Fody
安装:
搜索MethodTimer.Fody
安装:
快速使用
通过在方法上添加 Time
属性,MethodTimer 会在编译时自动向 TimeMethod
注入计时代码。
[Time]
public static void TimeMethod()
{
for (int i = 0; i < 100; i++)
{
Console.WriteLine($"输出结果{i}");
}
}
使用ILSpy查看编译后的代码
public static void TimeMethod()
{
Stopwatch stopwatch = Stopwatch.StartNew();
try
{
for (int i = 0; i < 100; i++)
{
Console.WriteLine($"输出结果{i}");
}
}
finally
{
stopwatch.Stop();
string message = null;
MethodTimeLogger.Log(MethodBase.GetMethodFromHandle((RuntimeMethodHandle)/*OpCode not supported: LdMemberToken*/, typeof(Program).TypeHandle), stopwatch.Elapsed, message);
}
}
耗时拦截器记录两种方法
运行耗时为long(毫秒):
/// <summary>
/// 运行耗时为long(毫秒)
/// </summary>
public static class MethodTimeLogger1
{
public static void Log(MethodBase methodBase, long milliseconds, string message)
{
Console.WriteLine($"方法:{methodBase.Name} 耗时:{milliseconds} 毫秒,信息:{message}");
}
}
运行耗时为TimeSpan:
/// <summary>
/// 运行耗时为TimeSpan
/// </summary>
public static class MethodTimeLogger
{
public static void Log(MethodBase methodBase, TimeSpan elapsed, string message)
{
Console.WriteLine($"方法:{methodBase.Name} 耗时:{elapsed.TotalMilliseconds} 毫秒,信息:{message}");
}
}
耗时统计时长输出
项目源码地址
更多项目实用功能和特性欢迎前往项目开源地址查看👀,别忘了给项目一个Star支持💖。
- 开源地址:https://github.com/Fody/MethodTimer
- MethodTimerExercise:https://github.com/YSGStudyHards/DotNetExercises/tree/master/MethodTimerExercise
优秀项目和框架精选
该项目已收录到C#/.NET/.NET Core优秀项目和框架精选中,关注优秀项目和框架精选能让你及时了解C#、.NET和.NET Core领域的最新动态和最佳实践,提高开发工作效率和质量。坑已挖,欢迎大家踊跃提交PR推荐或自荐(让优秀的项目和框架不被埋没🤞)。
版权声明:本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
上一篇:一文解秘Rust如何与Java互操作
下一篇:AOT使用经验总结
相关文章
最新发布
- Nuxt.js 应用中的 prerender:routes 事件钩子详解
- 【问题解决】Tomcat由低于8版本升级到高版本使用Tomcat自带连接池报错无法找到表空间的问题
- 【FAQ】HarmonyOS SDK 闭源开放能力 —Vision Kit
- 六、Spring Boot集成Spring Security之前后分离认证流程最佳方案
- 《JVM第7课》堆区
- .NET 8 高性能跨平台图像处理库 ImageSharp
- 还在为慢速数据传输苦恼?Linux 零拷贝技术来帮你!
- 刚毕业,去做边缘业务,还有救吗?
- 如何避免 HttpClient 丢失请求头:通过 HttpRequestMessage 解决并优化
- 让性能提升56%的Vue3.5响应式重构之“版本计数”