最初学习集合的时候,记得教材上讲得十分笼统:
“List list = new ArrayList(); 这么写体现了java语言的多态性”
工作以后总结了原因:
①java是面向对象语言,面向对象一个重要的原则就是“依赖倒置原则”。依赖抽象(接口),而非具体(实现类)。List是接口,ArrayList是实现类。它允许list可以轻松地在接口的不同实现之间切换。
这就好比你跟朋友说要买双篮球鞋,不要说你要买nike,否则当你路过价廉物美的李宁时,就要后悔刚和朋友说过的话了~
②List的实现类包括List,Vector,LinkedList , Stack…
使用List list = new ArrayList();你将来如果需要改成线程安全的Vector,不必注意一开始使用的是ArrayList还是Vector还是其他的实现类。而是只把创建时使用ArrayList改成Vector就行了。即List list = new Vector();
这种方法实现解耦合,大大提高代码使用的灵活性和通用性。
这点在暴露公共接口的时候尤其有用。比如你提供了这样的方法
public ArrayList getList();
然后你需要改成LinkedList
public LinkedList getList();
那么任何调用.getList()方法的人可能都需要更改他们的代码。另一方面,如果你这样做,
public List getList();
这样就不会对其他代码造成影响。
从这个例子可以推而广之
在new一个新对象时,左边尽量使用接口(或者抽象类),以保持代码的最大灵活性。
可能的例外
如果你确定以后这个集合被创建出来只可能是ArrayList,那么个人认为可能也可以用ArrayList.
因为如果碰到需要对这个list进行类型的判断就会比较麻烦啦,你要写很多类似 "else if(list instanceOf java.util.LinkedList)"这样的判断。不过这种情况很少见哈哈。