C# 使用 Fody 监控方法执行时间

写在前面

在做性能调优的时候,经常需要跟踪具体方法的执行时间;通过插入Stopwatch的方案对代码的侵入性太高了,所以引入了 MethodTimer.Fody 类库,采用编译时注入的方式给方法动态加上Stopwatch 跟踪代码,只需要在目标方法上添加 Time 属性标签,即可实现注入。

需要到NuGet安装一下Fody 和 MethodTimer.Fody

PM> Install-Package Fody

PM> Install-Package MethodTimer.Fody

代码实现

cs 复制代码
    
// 方法执行时长记录器
public static class MethodTimeLogger
{
    public static void Log(MethodBase methodBase, long milliseconds, string message)
    {
        Console.WriteLine($"方法:{methodBase.Name} 耗时:{milliseconds}秒, 信息:{message}");
    }
}

// 测试目标类
public class MethodTracer
{
    [Time("跟踪测试")]
    public void TestMethod()
    {
        Console.WriteLine("TestMethod: 开始执行");
        Thread.Sleep(123);
    }
}

调用示例:

var methodTracer = new MethodTracer();

methodTracer.TestMethod();

执行结果:

注意事项

有个需要特别注意的事情,否则注入代码无法生效,在项目中添加 FodyWeavers.xml 文件并将属性设置为"始终复制"。

Xml文件内容如下:

XML 复制代码
<?xml version="1.0" encoding="utf-8"?>
<Weavers xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="FodyWeavers.xsd">
  <MethodTimer />
</Weavers>

直接黏贴以下内容,vs会自动生成xsd

<Weavers>

<MethodTimer/>

</Weavers>

相关推荐
ylscode5 分钟前
黑客利用 GHOSTYNETWORKS 和 OMEGATECH 托管 JS 恶意软件基础设施
开发语言·安全·php·安全威胁分析
爱吃生蚝的于勒6 分钟前
QT开发第二章——信号和槽
c语言·开发语言·c++·qt
xcLeigh11 分钟前
Python入门:Python3 operator模块全面学习教程
开发语言·python·学习·教程·python3·operator
大叔带刺13 分钟前
使用python创建自己的专属星座签名APP:Name2Constell
开发语言·python·pygame
z落落15 分钟前
C# 类与对象、字段、静态与非静态+四大访问修饰符
开发语言·c#
思麟呀19 分钟前
C++工业级日志项目(八)最终上层接口
开发语言·c++
魔法阵维护师21 分钟前
从零开发游戏需要学习的c#模块,第三十二章(Boss 战系统)
学习·游戏·c#
石山代码25 分钟前
如何在 C++ 中实现多态?
开发语言·c++
阿方.91826 分钟前
C++ std::function 超全精讲 | 原理语法、适配对象、递归实现、回调场景、面试考点、易错坑点
开发语言·c++·bind·function
weixin_4684668529 分钟前
Markitdown 文档解析快速入门指南
开发语言·python·自动化·编程