4

我希望能够在代码执行进入方法然后退出时进行记录,我想知道是否有人对实现此目的的最佳方法有任何评论?

我知道存在一种在运行时注入日志代码的 AOP 方式,但我想拥有更多的控制权,而且 PostSharp 似乎是一个付费框架。

您会在这里推荐什么级别的日志记录,我认为是 DEBUG。

记录时间呢?方法进入vs退出需要多长时间

我很想知道其他人在这里做什么以及您正在使用什么框架。

我正在考虑使用 log4net。

我在考虑记录的是参数和方法的名称以及参数的值,退出时我正在考虑记录我返回的对象的值(如果有的话)..

其他人都在做什么?

提前致谢

4

2 回答 2

6

如果您不想使用 PostSharp(尽管有免费版本)或生成运行时代理,可以使用名为Afterthought的静态编织的开源替代方案。

或者,您可以使用其中一种分析工具。VS Ultimate 内置了一个。

于 2013-04-12T14:41:41.357 回答
5

好吧,您当然可以创建一个“一次性记录器”,它可以“自动”记录您选择的方法的信息:

public class EnterExitLogger : IDisposable
{
  Logger logger;
  string name;

  public EnterExitLogger(Logger logger, string name, params object [] args)
  {
    this.logger = logger;
    this.name = name;
    this.logger.Debug("Entering {0}", this.name);
    int i = 0;
    foreach (var a in args)
    {
      this.logger.Debug("arg[{0}] = {1}", i, a);
      i++;
    }
  }

  public void Dispose()
  {
    this.Logger.Debug("Exiting {0}", this.name);
  }
}

然后像这样使用它:

public class MyClass
{
  private static readonly Logger logger = LogManager.GetCurrentClassLogger();

  public void SomeMethod(int x, int y)
  {
    using (new EnterExitLogger(logger, "SomeMethod", x, y))
    {
      //Do your work here
    }
  }
}

这对我来说并不是一个特别好的主意,我怀疑我自己会不会这样做。另一方面,它确实在不使用 AOP 的情况下实现了某种形式的 Enter/Exit 日志记录。如果您真的想要“自动”进入/退出日志记录,我不确定如何在没有 AOP 或企业库版本(其名称让我忽略了)的情况下实现它。

显然,在我提出的解决方案中创建和处理 EnterExitLogger 会产生一些开销,但对你来说可能还不够。

于 2013-04-12T15:29:53.187 回答