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>

相关推荐
我命由我123451 分钟前
C++ - 头文件基础(常用标准库头文件、自定义头文件、头文件引入方式、防止头文件重复包含机制)
服务器·c语言·开发语言·c++·后端·visualstudio·visual studio code
能来帮帮蒟蒻吗17 分钟前
GO语言学习(17)Gorm的数据库操作
开发语言·学习·golang
baivfhpwxf202324 分钟前
prism WPF 对话框
c#·wpf
Pacify_The_North42 分钟前
【C++进阶五】list深度剖析
开发语言·c++·算法·list
咖啡の猫1 小时前
JavaScript 简单类型与复杂类型
开发语言·javascript
禹曦a1 小时前
Java进阶之旅-day05:网络编程
java·开发语言·网络
Evand J1 小时前
【MATLAB例程】TDOA(到达时间差)定位的chan-tylor计算方法,三维环境,附代码下载链接
开发语言·matlab
難釋懷2 小时前
JavaScript基础-移动端常用开发框架
开发语言·javascript
dot to one2 小时前
深入理解 C++ 三大特性之一 继承
开发语言·c++·visual studio
哈哈哈哈哈哈哈哈哈...........2 小时前
【无标题】object,wait,notifyAll
java·开发语言