我想记录有关正在执行的方法的某些信息,我认为 AOP 没问题,敲了一个演示,但我确实需要记录每个方法的特定信息,将其视为与调用相关的附加信息。
现在我考虑的选项只是在每种方法中记录它,但我认为它会污染代码,最后的手段,也许
或者我创建一个将方法映射到需要记录的信息的类,并使用 AOP 记录此信息。
你们有什么感想?
我想记录有关正在执行的方法的某些信息,我认为 AOP 没问题,敲了一个演示,但我确实需要记录每个方法的特定信息,将其视为与调用相关的附加信息。
现在我考虑的选项只是在每种方法中记录它,但我认为它会污染代码,最后的手段,也许
或者我创建一个将方法映射到需要记录的信息的类,并使用 AOP 记录此信息。
你们有什么感想?
另一种方法可能是装饰器模式/拦截器模式,但会增加编码工作量:
interface IComponent
{
int Foo(int input);
}
class Component : IComponent
{
public int Foo(int input)
{
return input * 2;
}
}
class LoggingComponent: IComponent
{
private readonly IComponent target;
public LoggingComponent(IComponent target)
{
this.target = target;
}
public int Foo(int input)
{
// ToDo: Add logging before method call
int returnValue = this.target.Foo(input);
// ToDo: Add logging after method call
return returnValue;
}
}
使用这种方法需要为要记录方法调用和输入/返回值的所有目标实现大量日志记录类。此外,您无法记录装饰器/拦截器转发到的目标方法内部发生的情况。
您还可以考虑使用环境上下文模式来实现横切关注点。有一个很好的博客:Ambient Context。