我有以下构造函数:
public DataImporterService(IList<IDataValidator> dataValidators, IList<IDataComparer> dataComparers, IList<IDataStorage> dataStorages)
{
_dataValidators = dataValidators;
_dataComparers = dataComparers;
_dataStorages = dataStorages;
}
这是我的注册:
Component.For<IDataComparer>().ImplementedBy<PlanOfRecordComparer>().Named("planOfRecordComparer"),
Component.For<IDataComparer>().ImplementedBy<PlanOfExecutionComparer>().Named("planOfExecutionComparer"),
Component.For<IDataComparer>().ImplementedBy<BomComparer>().Named("bomComparer"),
Component.For<IDataStorage>().ImplementedBy<PlanOfRecordStorage>().Named("planOfRecordStorage"),
Component.For<IDataStorage>().ImplementedBy<PlanOfExecutionStorage>().Named("planOfExecutionStorage"),
Component.For<IDataValidator>().ImplementedBy<PlanOfExecutionValidator>().Named("planOfExecutionValidator"),
Component.For<IDataValidator>().ImplementedBy<PlanOfRecordValidator>().Named("planOfRecordValidator"),
Component.For<IDataValidator>().ImplementedBy<BomValidator>().Named("bomValidator")
但是是否可以通过另一种方式注册组件而无需指定IDataComparer,IDataValidator和IDataStorage的每个实现?喜欢以更通用的方式?
好的,这就是我的工作方式:
首先,我使用了一个collectionresolver:
container.Kernel.Resolver.AddSubResolver(new CollectionResolver(container.Kernel));
要注册实现IDataComparer
,的所有类IDataStorage
,IDataValidator
Classes.FromThisAssembly().Where(x => x.Name.EndsWith("Validator")).WithServiceFirstInterface(),
Classes.FromThisAssembly().Where(x => x.Name.EndsWith("Comparer")).WithServiceFirstInterface(),
Classes.FromThisAssembly().Where(x=>x.Name.EndsWith("Storage")).WithServiceFirstInterface()
然后我就可以解决我的课程了:
public DataImporterService(IDataValidator[] dataValidators, IDataComparer[] dataComparers, IDataStorage[] dataStorages)
{ }
因此,当Castle Windsor尝试对DataImporterService进行解析时,它将获取所有实现注入接口的类,构造一个数组,将它们放入数组中,并将该数组作为依赖项的值提供。
这在此处的文档中提供
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句