以下代表书中的见解和我个人的摘录,如有问题请指出
1, 在构建一个类的实例时,我们有2个方法,一个是提供构造器,而另一个就是提供静态工厂方法(static factory method)。
2, 静态工厂方法与构造器不同的第一大优势在于,他们有名称。
3, 静态工厂方法与构造器不同的第二大优势在于,不必在每次调用它们的时候都创建一个新的对象。静态工厂方法能够为重复的调用返回相同的对象,这样有助于类总能严格控制某个时刻哪些实例应该存在,这种类被称做实力受控的类(instance-controlled),实例受控使得类可以确保它是一个Singleton或者是不可实例化的。
4, 静态工厂方法与构造器不同的第三大优势在于,它们可以返回原返回类型的任何子类型的对象。这个技术可以适用于基于接口的框架(interface-based framework)因为在这种框架中提供了自然返回类型,接口不能有静态方法,因此,接口Type的静态工厂方法被放在一个名为Types的不可实例化得类中。
5, 在jdk1.5中java.util.EnumSet,就引入了静态工厂,没有构造器。他对于不同参数返回不同实例。大于65个元素,返回JumboEnumSet,用long数组支持,小于则返回RegalarEumSet用long支持。
6, 静态工厂方法返回的对象所属的类,在编写包含该静态工厂方法的类时,可以不必存在。这种灵活的静态工厂方法构成了服务提供者框架(Service Provider Framework)的基础。(例如jdbc)
7, 服务提供者框架中有3个重要组件和1个可选组件:服务接口(Service Interface),这个是提供者实现的;提供者注册API(Provider Registration API),这个是系统用来注册实现,让客户端访问他们的;服务访问API(Service Access API),是客户端用来获取服务的实例的。服务提供者接口(Service Provider Interface)是一个可选的组件。
举例来说(对于JDBC来说,Connection is Service Interface;DriverManager.registerDriver is Provider Registration API;DriverManager.getConnection is Service Access API,Driver is Service Provider Interface)
8, 静态工厂方法的第四大优势在于,在创建参数化类型实例的时候,它们使代码变得更加简洁。但是在调用参数化类的构造器时,即使类型参数很明显,也必须指明。导致代码如下
Map<String,List<String>>m=new HashMap<String,List<String>>();
可以通过类型辅助(type inference)来改善这个问题。
Public static<k,v>HashMap<k,v> newInstance(){ return new HashMap<k,v>(); } Map<String,List<String>> m=HashMap.newInstance();
9, 静态工厂方法的主要缺点在于,类如果不含有公有的或者受保护的构造器,就不能被子类化。
10, 静态工厂方法的第二个缺点在于,它们于其他的静态方法实际上没有任何区别。
11, 静态工厂方法的一些惯用名称:valueOf,of,getInstance,newInstance,getType,newType