在java开发中经常会听到这样的话,“针对接口编程,不针对实现编程”,可能你已经知道了,但是在这里我还是啰嗦一下,使用接口编程,可以隔离掉以后系统可能发生的一大推改变。为什么呢?如果代码是针对接口写的,那么通过多态,它可以与任何新类实现该接口。但是,当代码使用大量的具体类时,等于自找麻烦,因为一旦加入新的具体类就要修改源代码。
1.当看到“new”,就会想到“具体”
是的,当使用“new”时,你的确是在实例化一个具体类,所以用的确实是实现,而不是接口。这样代码绑着具体类会导致代码更脆弱,更缺乏弹性。
interface Duck{
...
}
class MallardDuck implements Duck{
...
}
Duck duck (使用duck让代码具有弹性) = new MallardDuck();
当有一群相关的具体类时,通常会写出这样的代码
Duck duck = null;
if(type){
duck = new MallardDuck();
}else if(type1){
duck = new DecoyDuck();
}else if(type2){
duck = new RubberDuck();
}
这里有一些要实例化的具体类,究竟要实例化那个类,要在运行时有一些条件决定。
当看到这样的代码,一旦出现变化或者扩展就必须修改这段代码,修改次数越多,出现错误的几率越大。同时这段代码的重用性不高。所以,该怎么办,当遇到这种情况,就应该回到oom设计原则中寻找线索。有一个原则是“找出变化的方面,把它们从不变的部分分离出来”