亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C#使用Fody實現(xiàn)監(jiān)控方法執(zhí)行時間

 更新時間:2023年11月30日 09:01:13   作者:rjcql  
這篇文章主要為大家詳細介紹了C#如何使用Fody實現(xiàn)監(jiān)控方法執(zhí)行時間,文中的示例代碼講解詳細,具有一定的學習價值,感興趣的小伙伴可以了解下

寫在前面

在做性能調(diào)優(yōu)的時候,經(jīng)常需要跟蹤具體方法的執(zhí)行時間;通過插入Stopwatch的方案對代碼的侵入性太高了,所以引入了 MethodTimer.Fody 類庫,采用編譯時注入的方式給方法動態(tài)加上Stopwatch 跟蹤代碼,只需要在目標方法上添加 [Time] 屬性標簽,即可實現(xiàn)注入。

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

PM> Install-Package Fody
PM> Install-Package MethodTimer.Fody

代碼實現(xiàn)

// 方法執(zhí)行時長記錄器
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: 開始執(zhí)行");
        Thread.Sleep(123);
    }
}

調(diào)用示例:

            var methodTracer = new MethodTracer();
            methodTracer.TestMethod();

執(zhí)行結(jié)果

注意事項

有個需要特別注意的事情,否則注入代碼無法生效,在項目中添加 FodyWeavers.xml 文件并將屬性設(shè)置為"始終復制"。

Xml文件內(nèi)容如下:

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

直接黏貼以下內(nèi)容,vs會自動生成xsd

<Weavers>
  <MethodTimer/>
</Weavers>

到此這篇關(guān)于C#使用Fody實現(xiàn)監(jiān)控方法執(zhí)行時間的文章就介紹到這了,更多相關(guān)C#監(jiān)控方法執(zhí)行時間內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

最新評論