我想知道一些最佳实践是围绕日志和日志框架和依赖注入。具体来说,如果我设计一个需要日志记录的类,我应该如何获得一个接口来记录依赖注入?
依赖注入似乎声明外部依赖应该从外部注入(构造函数或属性setters),所以我应该在构造函数中使用ILog实例并在类中使用?我应该考虑记录一个可选的依赖项并在setter中获取它吗?我通过允许日志接口改变,我只是对一个特定的日志接口(通过例如通过调用工厂方法创建一个静态ILog变量)硬依赖推动太多的灵活性?可能这个工厂方法调用到容器中以获得ILog实现,或者这将创建初始化的静态变量和初始化IoC容器之间的初始化冲突?
我应该这样做:
public class MyService : ISomeService { private static readonly ILogger s_log = LoggingFactory.GetLogger(typeof(MyService)) ... }
或者也许这:
public class MyService : ISomeService { protected virtual ILogger Logger {get; private set;} public MyService(ILogger logger,[other dependencies]) { Logger = logger; } }
或甚至这:
public class MyService : ISomeService { public virtual ILogger Logger {get; set;} public MyService() { } }
其他模式或方法来做到这一点?什么人在那里做?什么是工作和什么时候?