多用静态工厂代替构造器

简介: 这一节其实也是在说明工厂设计模式的优秀之处,它相对于构造函数的优势在于:

这一节其实也是在说明工厂设计模式的优秀之处,它相对于构造函数的优势在于:


静态工厂方法有名称

比如BigInteger.probablePrime这个静态方法让人一眼就能看出构造的对象可能是素数


可以不在每次调用时都创建一个新对象

可以参考Spring里面创建单例的逻辑,将构建好的实例存在缓存里返回;而我们调用构造函数时总会创建一个新对象。


静态工厂可以返回原类的子类


class A{
  // 构造函数只能得到本类的一个对象
  public A(){...}
  // 静态构造方法可以得到A的子类
  public static A的子类 XXXFactory(){...}
}


此外,Spring源码里的BeanFactory是工厂设计模式很好的实践,有异曲同工之妙~


可以使用静态工厂方法的入参来控制返回的对象类型

例如EnumSet类的静态工厂方法可以根据入参的元素个数来决定返回RegularEnumSet实例还是JumboEnumSet实例


方法返回的对象所属的类,在编写包含该静态工厂方法的类时可以不存在

这个乍一看有点拗口,但实际上说的还是返回值可以是子类,举个例子:JDBC数据库连接API大家肯定都用过吧,里面的Driver,Connection,Statement都是借口,当我们真正使用时其实用的是厂商的实现类,在编写JDBC时,某些数据库可能根本还没有被研发出来,但后来我们都能使用的原因就是数据库厂商做了对接。


聊完了静态工厂方法的优点,我们可以再聊一聊缺点,这样才能更清楚作者为什么提倡我们这样做:


类如果不含有public的或protected的构造器,就不能被子类化。

通俗一点讲就是,静态工厂方法的本质是,通过返回这个函数返回值的子类,实现灵活性。但是由于子类继承父类,子类的构造函数会默认调用父类的无参构造函数,如果没有就需要显示调用同参的父类构造函数,因此如果父类的构造函数不是共有的或者protected那么就无法实例化子类,那么静态工厂方法就没有意义。


不过作者也介绍了这或许可以“因祸得福”,因为这样鼓励程序员使用复合而不是继承


在API文档里,他们没有想构造函数那样被明确标记出来。

在类的注释里将静态工厂标注出来可以解决,并且javadoc日后必定会增加这一块内容。


相关文章
|
移动开发 前端开发 物联网
分享139个HTML公司企业模板,总有一款适合您
分享139个HTML公司企业模板,总有一款适合您
268 0
基于Multisim的BJT共射电路的仿真
下面是基于Multisim的BJT共射电路的仿真步骤: 1. 打开Multisim软件,创建新的仿真文件。 2. 在Components栏中选择BJT晶体管,将其拖放到工作区中。 3. 在Components栏中选择电源,将其拖放到工作区中。 4. 在Components栏中选择电阻,将其拖放到工作区中。 5. 连接电源和地线。 6. 连接电阻和BJT晶体管,形成基本的共射电路。 7. 右键单击电源,选择Properties,设置电源电压。 8. 右键单击电阻,选择Properties,设置电阻值。 9. 设置其他仿真参数,如仿真时间、仿真步长等。 10. 运行仿真,观察输出波形和电路性能参数
586 0
域名备案的流程是什么?
域名备案的流程是什么?
2177 30
|
SQL Oracle 关系型数据库
SqlAlchemy 2.0 中文文档(六十八)(1)
SqlAlchemy 2.0 中文文档(六十八)
67 0
|
存储
ThreadLocal
ThreadLocal
94 0
|
SQL 存储 分布式计算
Hive的分桶详解
Hive的分桶详解
187 0
|
数据可视化 数据挖掘
14个Seaborn数据可视化图(下)
14个Seaborn数据可视化图
229 0
14个Seaborn数据可视化图(下)
|
Kubernetes Cloud Native 容器
《深入浅出Kubernetes》下载地址
《深入浅出Kubernetes》分为理论篇和实践篇,12篇技术文章帮你了解集群控制、集群伸缩原理、镜像拉取等理论,一次搞懂6个核心原理吃透基础理论,实现从基础概念的准确理解到上手实操的精准熟练,深入浅出使用Kubernetes!
117 0
《深入浅出Kubernetes》下载地址
Google Earth Engine——gee中的小bug跨洲边际的影像无法获取
Google Earth Engine——gee中的小bug跨洲边际的影像无法获取
162 0
Google Earth Engine——gee中的小bug跨洲边际的影像无法获取