ソリューションで Ninject を構成するための次のコード ブロックがあります。
public class NinjectDependencyScope : IDependencyScope
{
private IResolutionRoot resolver;
internal NinjectDependencyScope(IResolutionRoot resolver)
{
Contract.Assert(resolver != null);
this.resolver = resolver;
}
public object GetService(Type serviceType)
{
if (resolver == null)
{
throw new ObjectDisposedException("this", "This scope has already been disposed");
}
return resolver.TryGet(serviceType);
}
public IEnumerable<object> GetServices(Type serviceType)
{
if (resolver == null)
{
throw new ObjectDisposedException("this", "This scope has already been disposed");
}
return resolver.GetAll(serviceType);
}
public void Dispose()
{
Dispose(true);
GC.SuppressFinalize(this);
}
protected virtual void Dispose(bool disposing)
{
if (disposing)
{
IDisposable disposable = resolver as IDisposable;
if (disposable != null)
{
disposable.Dispose();
}
resolver = null;
}
}
私の意見では、ここで使用されている使い捨てパターンは必要ありません..
IDependencyScope は IDisposable ですが、IDisposable メンバーを構築している場合にのみクリーンアップする必要がありますが、コンストラクターに挿入されたリゾルバーはクラスによって所有 (作成) されておらず、IResolutionRoot は IDisposable から派生/実装していません...
私はここにいますか?
(参照用に IDisposable パターンに関するこの記事を確認してください)
(編集): これは実際には次のクラスで使用される基本クラスであるため、ここで IDisposable 実装を削除することはできません...
public class NinjectDependencyResolver : NinjectDependencyScope, IDependencyResolver
{
private IKernel kernel;
public NinjectDependencyResolver(IKernel kernel)
: base(kernel)
{
this.kernel = kernel;
}
public IDependencyScope BeginScope()
{
return new NinjectDependencyScope(kernel.BeginBlock());
}
}