我有一个静态日志管理器类,它应该根据参数返回所需记录器的实例。
public static class LogManager {
private static ILoggerFactory Factory { ... }
public static ILogger GetLogger(string name) {
return Factory.Create(name);
}
}
由于必须设置ILoggerFactory的具体实现(初始化),我想知道我是否应该只保留对实现类型的引用,并在每次请求工厂时返回一个新实例 - 或者是否可以保留实现实例的静态引用。
版本1
private static Type _factoryType;
public static void SetFactory<TFactory>()
where TFactory : ILoggerFactory, new()
{
_factoryType = typeof(TFactory);
}
private static Factory {
get { return (ILoggerFactory)Activator.CreateInstance(_factoryType);
}
public static ILogger GetLogger(string name) {
return Factory.Create(name);
}
版本2
private static ILoggerFactory _loggerFactory;
public static void SetFactory<TFactory>()
where TFactory : ILoggerFactory, new()
{
_loggerFactory = (ILoggerFactory)Activator.CreateInstance<TFactory();
}
public static ILogger GetLogger(string name) {
return _loggerFactory.Create(name);
}
答案 0 :(得分:2)
可以说,主要区别似乎是延迟加载:v1将在调用GetLogger
时创建记录器类型,而v2将在SetFactory
期间创建记录器。否则没有太大的区别。可以将引用作为专用静态字段保存到记录器的类型或工厂本身。
但是,如果这是生产代码,我将完全摆脱这个日志管理器和工厂。相反,我会使用日志框架,例如nlog或log4net 直接。这简化了代码并使其更易于维护。在这种情况下,构建抽象是过度工程。