Effective Java第三版(一) ——用静态工厂代替构造器
此文做为《Effective Java》系列的第一篇,所以有必要大概说下此书的特点,当然很多人可能都看过,毕竟是有着Java四大名著之一的大名在外,不过总会有萌新不了解,例如我!《Effective Java》第三版较之上一版新增了对Java7、8、9的一些新特性的条目。而条目的概念可以理解为武功秘籍中的一招一式,学完了每一招一式,就是神功大成之时。第三版在第二版的基础上新增了一些条目数,达到了90条。书就介绍到这里,下面介绍第一条——用静态工厂代替构造器。
对于创建对象,最熟悉的莫过于使用new关键字调用对象提供的构造器来创建对象,而此书的第一条告诉我们,类可以提供一个公有的静态工厂方法来创建对象。(ps:这里的静态工厂方法并不直接对应设计模式中的工厂模式,请大家不要对号入座),首先我们来看一看静态工厂方法的优点,也就是为什么我们要使用它。
五大优点:
一.它有名称。这样说是因为,构造器必须与类同名,一个类无论有多少构造器,它们的名字都是一样的,即和类同名。但是静态工厂方法不同,它可以有具体意义的名称,例如一个User类可以有一个adminUser()方法来提供一个管理员用户。
二.不必在每次调用它们的时候都创建一个新对象。如以下代码,可以有效的避免创建不必要的重复对象。
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); }
三.可以返回原返回类型的任何子类型,主要适用于基于接口的框架。
四.所返回的对象可以随着每次调用而发生变化,这取决于静态工厂方法的参数值。
五.方法返回的对象所属类,在编写包含该静态工厂方法的类时可以不存在。
两个缺点:
一.类如果不包含公有的或者受保护的构造器,就不能被子类化。
二.程序员很难发现它。
总结:静态工厂方法与构造器各有优缺点,我们需要理解各自的长处,以便更加合适的使用。相对来讲静态工厂方法能够提供更加强大的功能,当我们做为服务方时静态工厂方法无疑能使我们提供的服务更加灵活多变和强大。而对于它的两个缺点,尤其是第二缺点完全可以通过命名的规范化及良好的注释来规避这一缺点。
附:
静态方法常用命名:
• from 类型转换方法,如:Date date = Date.from(Instant.now());
• of 聚合方法,如Set<ResolverStyle> styles = EnumSet.of(ResolverStyle.LENIENT,ResolverStyle.SMART,ResolverStyle.STRICT);
• valueOf 比from和of更繁琐的一种替代方法,如:BigInteger prime = BigInteger.valueOf(Integer.MAX_VALUE);
• instance或者getInstance 常用作单例模式的实现;
• create或者newInstance 每次调用返回新的实例;