第一条、考虑用静态工厂方法代替构造器
优势点:
1.有名称
这个好理解,构造器名称必须都一样,所以无法做细致的区分,而工厂方法可以任意命名你可以区分的名字
比如valueOf
2.不必每次调用的时候都创建一个新对象
这个要进行分场景理解,比较特别的单例类,它可以通过私有化构造器,然后通过静态工厂方法来提供唯一的对象
或者对于一些创建对象代价比较高的类,也可也缓存一些对象,然后通过静态工厂方法提供,我比较熟悉的就是线程池
3.可以返回原返回类型的任何子类型的对象
也就是这里实例化的,不一定要是当前的类本身,可以是当前类的子类,而且这个子类如果很繁杂,不想提供给外界看,就可以是定义在当前类的内部。
这里提到服务提供者框架,并且以JDBC为例子
4.在创建参数化类型的时候,可以使代码简洁
这个主要是针对范型,Map<String, List<String>> instance = HashMap.newInstance();
缺点:
1.类如果没有公有的或者受保护的构造器,就不能被子类化
这点也就是说,我如果想要在静态工厂方法里面去返回一个子类的实现就会很困难,因为这里不能被子类化了
2.与其他的静态方法没有什么明显的区分
这样会容易造成,你不知道怎么区分它们和静态方法,必须要有健全的文档
第二条、遇到多个构造器参数时要考虑用构建器