通过构造函数传递实例或使用静态访问它?

时间:2017-07-19 03:29:57

标签: java

最近,我一直使用Bukkit API进行编码,但我的问题与它没有直接关系。

在Bukkit API中,可以有一个主类的单个实例(new MainClass()抛出错误),所以我想知道,将主类传递给我的所有类是否更好?一个构造函数,或者我应该只使用一个返回实例(MainClass.getInstance()

的静态方法

我很好奇哪一个更好(在表现和实践方面)。

1 个答案:

答案 0 :(得分:3)

在实践方面,更好的方法是你的第一个建议:

  

使用构造函数将主类传递给我的所有类

这称为dependency injection,是preferred alternative over global access

它不鼓励过度曝光(鼓励encapsulation,这很好),并允许natural mocking(反对使用像PowerMock这样的框架)使测试更容易。如果可能,建议您使用此方法。

至于你的第二个建议:

  

我应该只使用返回实例的静态方法

这种做法往往不受欢迎,特别是如果Main是可变的。

如果公开全局可变实例,则引入全局状态tends to be a pain

任何依赖它的模块都可能会与依赖它的其他模块耦合。这被称为common coupling,如果可能的话应该避免,因为它是最紧密的耦合形式之一。

全局访问使访问变得更容易,但代价可能是纠缠不清的代码。它应该只在需要时使用。