当涉及到设计类以及它们之间的“通信”时,我总是尝试以所有对象构造和组合都在对象构造函数中进行的方式进行设计。我不喜欢从外部进行对象构造和组合的想法,就像其他对象设置属性并调用我的对象上的方法来初始化它一样。当多个对象尝试对您的对象执行此操作并且您永远不知道您的 props\methods 将以什么顺序执行时,这尤其变得丑陋。
不幸的是,我经常遇到这种情况,特别是现在随着依赖注入框架的日益流行,许多库和框架依赖于某种外部对象初始化,并且通常不仅需要对我们的对象进行构造函数注入,还需要属性注入。
我的问题是:
可以让对象依赖于某种方法或属性来调用它们,然后它们可以认为它们已初始化吗?
当您的对象充当接收者并且必须支持调用它的多个接口并且这些调用的顺序很重要时,是否存在某种模式? (比设置标志更好的事情,例如 ThisWasDone、ThatWasCalled)
可以让对象依赖于某种方法或属性来调用它们,然后它们可以认为它们已初始化吗?
不。初始化方法很痛苦,因为不能保证它们会被调用。一个简单的解决方案是切换到接口并使用工厂或构建器模式来组成实现。
@Mark Seemann 写了一篇关于它的文章:http://blog.ploeh.dk/2011/05/24/DesignSmellTemporalCoupling.aspx http://blog.ploeh.dk/2011/05/24/DesignSmellTemporalCoupling.aspx
当您的对象充当接收者并且必须支持调用它的多个接口并且这些调用的顺序很重要时,是否存在某种模式? (比设置标志更好的事情,例如 ThisWasDone、ThatWasCalled)
生成器模式。
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)