Effective Java第一节
第1条:考虑用静态工厂方法代替构造器
首先清楚什么是静态工厂方法?
静态工厂方法说白了就是在创建对象的时候,不是自己使用new关键字创建的,而是使用静态方法来对外提供自身的实例的方法。
比如:
fragment fragment=myfragment.newintance(); calendae calendae=calendae.getintance(); integer integer=integer.valueof(“3”); |
new关键字代表着程序执行到这里的时候,jvm会创建一个内存空间,然后调用构造函数来初始化成员变量,最终把引用返回给调用方。
我自己的理解是:类似使用单利模式进行创建,直接调用创建对象的那个方法。
静态工厂方法与构造器不同的四大优势:
第一大优势,它们有名称。
我们都知道,在实例化类的时候,往往会调用类中的构造函数,构造函数的名称是相同的,只有参数不同,参数可以有顺序,类型的不同,从而是整个构造方法不同。这给我们带来的麻烦就是,很多时候我们会不知道要使用哪个或者使用这个构造函数往往需要填写不需要的数据,数量少还好说,万一数量多了,数据就不受控制了。这个时候,静态工厂方法的优势就体现出来了,直接使用名称的形式简单明了。
第二大优势,不必每次调用他们的时候都创建一个新对象。
这里可以使用单利的思维思考,因为单利的目的就是为了不重复创建对象。它可以每次都返回一个对象,进行重复使用。在很多情况下,这种方式可以让开发人员清楚的把控创建的对象,有利于开发与维护。还有利于性能的提升。
第三大优势,它们可以返回原类型的任何子类型的对象。
在设计模式中的基本原则之一------->里氏替换,就是说子类能替换父类
显然,构造方法只能返回确切的自身类型,而静态工厂能更加灵活,可以根据需要方便的返回它的任何子类类型的实例。
例如:
以上代码可以清楚的发现,使用person可以返回person的实例,也可以使用子类返回person的实例。
第四大优势,在创建参数化类型实例的时候,使得代码更加简洁。
这个优势我觉得没有多大的解释意义,如下代码
map<string.list<string>> map=new hashmap<string,list<string>>(); |
这个实例需要创建的时候,需要写那么冗长,很多时候吃不消,然后就有了如下的设计
public static <k,v> hashmap<k,v> newinstance(){ return new hashmap<k,v>(); } 使用的时候就直接使用下面这个就简洁多了。 |
map<string,list<string>> map=hashmap.newinstance(); |
所以我觉得用起来方便,但是它们内部把之前要做的步骤都做了,展现的是我们看到的,这个好处就显而易见了。
静态共仓方法的缺点:
第一缺点:类如果不含有公有的或者受保护的构造器,就不能被子类化:
这句话的理解是:就是说在创建静态工厂的时候,使用私有的关键词修饰了之后,子类就实例化不了父类的实例。
第二个缺点:它们与其他静态方法实际上没有任何区别。
总结:静态工厂与构造器各有千秋,我们理解了它们之后,需要使用各自的长处,而不是一贯的使用构造方法,忘记静态工厂方法。
上一篇: 移动端网站优化要怎么做?