我正在比较从域模型中使用服务的可能性(在流程本地组件的意义上,如 Windsor IoC 容器中)。
我有 3 种方法可以实现这一目标:
发布域事件并让服务层代码处理它
通过模型对象上的方法注入服务
在模型对象中注入服务
(4. 使用服务定位器)
第一个导致了非常有表现力和重复性的模式,以过程风格为其他简单的任务创建域事件和处理程序。但它具有模型与其所使用环境的最佳解耦(模型是自定义的)。
第二个使方法参数更长并且看起来像它破坏了封装(如果模型对象的操作需要其他服务,则所有调用者都必须更改)。
第三个将注入当前事务不需要的依赖项。为此,还需要“扩展”NHibernate。由于阅读了其他建议,我会避免使用这种方法。
因为我想在我们的文档中写这个,我需要告诉读者什么时候使用哪种方法。我正在考虑“如果要将域事件处理程序放入模型程序集中,请使用方法注入”,但它并没有真正切中要害。
对这条规则的建议?