我正在处理的应用程序依赖于Autofac作为DI容器,其中一个原因让我决定使用它,其中包括委托工厂功能(见
here)
这适用于我需要多次重建相同元素的所有情况,如某些报告和相关屏幕的情况.一些报告(甚至那些相同类型的报告)是同时执行的,但它们仅通过用户定义的参数进行更改,因此注入工厂以创建实例,传递免费参数并将其余参数留给应用.
问题在于每个报告由可变数量的子报告(任务)组成,每个任务都实现ITask接口.每个报告最多可以使用50个不同的任务,每个任务都包含一个精确的业务操作.我有一个选择是注入委托工厂并在需要时创建它们.
这些任务必须由工厂动态生成,例如:
var myTaskA = _taskFactoryConcreteTaskA(); var myTaskB = _taskFactoryConcreteTaskB(); var myTaskC = _taskFactoryConcreteTaskC(); ... var myTaskZZ = = _taskFactoryConcreteTaskZZ();
var myTaskA = _taskFactory.Create<ConcreteTaskA>(); var myTaskB = _taskFactory.Create<ConcreteTaskB>(); var myTaskC = _taskFactory.Create<ConcreteTaskC>(); ... var myTaskZZ = _taskFactory.Create<ConcreteTaskZZ>();
如果_taskFactory包装容器如this other post所示,那将是非常少的工作,但它也基本上意味着我使用服务定位器来创建我的任务.
我还有哪些其他选择可能适合解决这个问题?
(注意:我很有可能完全偏离轨道,我必须阅读更多有关DI的内容,在这种情况下,任何贡献都会更加重要)
解决方法
值得研究的一种方法是将问题分解为使用一组相关任务的“工作单元”:
public class WorkItem1 : ISomeWork { public WorkItem1(Task1 t1,Task2 t2...) { } public void DoSomething() { ... } }
然后,你对工厂的使用会降向someWorkFactory().DoSomething(),可能会出现几种不同的’某事’.
在工厂或其他任何事物上具有大量依赖关系的类通常指向等待被发现以打破工作的更小,更集中的类.
希望这可以帮助.