第一条:考虑用静态工厂方法代替构造器

来源:互联网 发布:windows pe 知乎 编辑:程序博客网 时间:2024/05/23 19:13

获取类的实例,类可以提供一个公有的构造器,还可以提供一个公有的静态工厂方法(static factory method),它只是一个返回类的实例的静态方法。例如:

public static Boolean valueOf(boolean b){      return b ? Boolean.TRUE : Boolean.FALSE;}

注意,这里的静态工厂方法与设计模式中工厂方法模式不同,使用静态工厂方法有如下的优势和劣势

优势

1.它们有名称。便于使用和阅读,当一个类需要多个带有相同签名的构造器,用静态工厂方法代替构造器,并慎重地选择名称以便突出它们之间的区别。
2.不必在每次调用它们的时候都创建一个新的对象。
3.它们可以返回原返回类型的任何子类型的对象。
4.在创建参数化类型实例的时候更加简洁。类型推导(type inference),例如:
Map<String,List<String>> m = new HashMap<String,List<String>>();
如何参数类型较多,就会很复杂,可以提供一个静态工厂
public static <K,V> HashMap<K,V> newInstance(){     return new HashMap<K,V>();}
就可以这样调用
Map<String,List<String>> m = HashMap.newInstance();

劣势

1.类如果不含公有的或者受保护的构造器,就不能被子类化
2.它们与其它的静态方法实际上没有任何区别

静态工厂一些惯用的名称:
  • valueOf——该方法返回的实例与它的参数具有相同的值,实际上是类型转换方法
  • of
  • getInstance——返回的实例是通过方法参数来描述的,但不能说与参数具有同样地值
  • newInstance——能够确保返回的每个实例都与所有其他实例不同
  • getType——工厂方法处于不同的类中使用,Type表示返回的对象类型
  • newType——工厂方法处于不同的类中使用,Type表示返回的对象类型

静态工厂方法和公有构造器都各有用处,我们需要理解它们各自的长处。静态工厂通常更加适合,因此可以优先考虑静态工厂。



0 0
原创粉丝点击