静态工厂方法的一个好处是,与构造方法不同,静态工厂方法具有名字。
例如:
BigInteger要产生一个素数,那么
public static BigInteger java.math.BigInteger.probablePrime(int bitLength, Random rnd)
比构造方法好,好在代码的可读性。
静态工厂方法的第二个好处是,与构造方法不同,他们每次被调用的时候,不要求非得创建一个新的对象。
例如:
java.lang.Boolean的代码里:
public static final Boolean TRUE = new Boolean(true);
public static final Boolean FALSE = new Boolean(false);
public static Boolean valueOf(boolean b) {
return (b ? TRUE : FALSE);
}
静态工厂方法的第三个好处是,与构造方法不同,它们可以返回一个原返回类型的子类型的对象。
例如:
Collections.singletonList提供了不可修改的list。
Collections.synchronizedList提供了同步后的list。
不可修改的list和同步的list,是通过静态工厂方法导出来的。
Collections.singletonList返回的是SingletonList,该类不是公有的,是List的实现类。
Collections.synchronizedList返回的是SynchronizedList,该类也不是公有的,也是List的实现类。
静态工厂方法的主要缺点是,类如果不含有公有的或者受保护的构造方法,就不能被子类化。
例如:
上面的SingletonList,SynchronizedList,是不能实例化的,因为它们是私有的内部类。也不能实例化Collections,因为它的构造方法是私有的。
静态工厂方法的第二个缺点是,它们与其他的静态方法没有任何区别。
所以,有些静态方法是工厂方法,有些则不是,不过,valueOf和getInstance这两个方法名,一般是看做静态工厂方法的。