最近,我一直使用Bukkit API进行编码,但我的问题与它没有直接关系。
在Bukkit API中,可以有一个主类的单个实例(new MainClass()
抛出错误),所以我想知道,将主类传递给我的所有类是否更好?一个构造函数,或者我应该只使用一个返回实例(MainClass.getInstance()
)
我很好奇哪一个更好(在表现和实践方面)。
答案 0 :(得分:3)
在实践方面,更好的方法是你的第一个建议:
使用构造函数将主类传递给我的所有类
这称为dependency injection,是preferred alternative over global access。
它不鼓励过度曝光(鼓励encapsulation,这很好),并允许natural mocking(反对使用像PowerMock这样的框架)使测试更容易。如果可能,建议您使用此方法。
至于你的第二个建议:
我应该只使用返回实例的静态方法
这种做法往往不受欢迎,特别是如果Main
是可变的。
如果公开全局可变实例,则引入全局状态tends to be a pain。
任何依赖它的模块都可能会与依赖它的其他模块耦合。这被称为common coupling,如果可能的话应该避免,因为它是最紧密的耦合形式之一。
全局访问使访问变得更容易,但代价可能是纠缠不清的代码。它应该只在需要时使用。