通常获得一个类的实例是通过该类的public constructor,item 1提醒程序员们还有另外一种可以实例化类的方法,就是使该类提供static factory方法,并且推荐优先使用static factory方法来实例化类。
static factory 主要的优点有:
1. 比起public constructor,static factory可以有自己的方法名。
构造函数通过参数的不同来区分返回对象的不同,仅仅通过参数的不同不容易区分出对象的差异,static factory可以通过名字的不同来返回不同类型的对象,这样比较容易区分返回的对象。
2. 和constructor不同,static factory不一定每次调用都要返回新的对象。
在一些不经常改变的类中用static factory比较合适,比如Boolean.valueof()方法。可以进行类实例的数量的控制和管理。
3. static factory返回的实际对象类型可以是任何返回类型的子类型。
可以隐藏实际返回对象类型的具体实现,仅仅暴露给用户接口,当升级的时候具体实现可以变,而接口不用变,这样易于维护。
4. 当类带参数时,通过constructor比较冗长,用static factory可以避免过于冗长的代码。
主要缺点:
- 如果类只提供static factory方法,而没有public或protected的构造方法,该类不能够子类化。
- static factory方法之间不是很容易区分。