これは、コンストラクタインジェクションを使用してServiceLocatorパターンを回避する正しい方法ですか?
public interface IEntitySomethingBase<TEntity>
{
//Stuff
}
public class AccountEntitySomething : IEntitySomethingBase<Account>
{
//Stuff
}
public class CustomerEntitySomething : IEntitySomethingBase<Customer>
{
//Stuff
}
public class OrderEntitySomething : IEntitySomethingBase<Order>
{
//Stuff
}
//Ditto, any number
避けたいServiceLocatorを使用したクラスの消費。
public class MyConsumingClass
{
public object DoSomething<TEntity>(TEntity entity)
where TEntity : class
{
var thing = ServiceLocator.Current.GetInstance<IEntitySomethingBase<TEntity>>();
}
}
MEFを使用したソリューション。上記を変更*EntitySomething'sto Export、および
public class MyConsumingClass
{
private List<Lazy<IEntitySomethingBase<Object>>> _things;
[ImportingConstructor]
public MyConsumingClass([ImportMany] List<Lazy<IEntitySomethingBase<Object>>> things)
{
_things = things;
}
public object DoSomething<TEntity>(TEntity entity)
where TEntity : class
{
var thing = _things.Cast<IEntityInformationExtractor<TEntity>>().Where(t => t.GetType().FullName == entity.GetType().FullName).FirstOrDefault();
}
}
実際にはまだ試していませんが、これを達成する他の方法はどこにあるのだろうかと考えていました。
ありがとう