为什么要用接口引用指向实现类的对象?
这种写法其实java多态的表现形式
多态的定义:
指允许不同类的对象对同一消息做出响应。
即同一消息可以根据发送对象的不同而采用多种不同的行为方式。
(发送消息就是函数调用
List list;是在栈区开辟一个空间放list引用,并没有创建对象所以不知道ArrayList还是LinkedList
当你list= new ArrayList(); 就创建了ArrayList对象。
并且把开始创建的list引用指向这个对象ArrayList和LinkedList都是List的实现类。
为什么一般都使用 List list = new ArrayList() ,而不用 ArrayList alist = new ArrayList()呢?
?
问题就在于List有多个实现类,如 LinkedList或者Vector等等,现在你用的是ArrayList,
也许哪一天你需要换成其它的实现类呢?,这时你只要改变这一行就行了:
List list = new LinkedList(); 其它使用了list地方的代码根本不需要改动。
假设你开始用 ArrayList alist = new ArrayList(),
这下你有的改了,特别是如果你使用了 ArrayList特有的方法和属性。
,如果没有特别需求的话,最好使用List list = new LinkedList(); ,便于程序代码的重构.
这就是面向接口编程的好处
注意事项
list只能使ArrayList中已经实现了的List接口中的方法
,ArrayList中那些自己的、没有在List接口定义的方法是不可以被访问到的
list.add()
其实是List接口的方法
但是调用ArrayList的方法如 clone()方法是调用不到的
ArrayList源码分析:
1.add(int index ,Object obj):首先判断是否越界?数组拷贝的原理;把index 拷贝到index+1,size-1
是拷贝长度,将元素添加到索引为index的位置上,元素的个数+1
2.get(int index):根据索引获取元素对象,调用elementDate(index)方法:在Object类型的数组中
根据索引取出元素对象
3.size():每次添加size+1
4.isEmpty():判断元素是否一个没有返回布尔类型的值
5.set(int index):在指定索引位置修改我们对象:调用elementDate(index)方法:根据索引把元素调出
再设置新的元素到index位置,返回一个old元素后 设置成功
6.remove(int index):调用elementDate(index)方法:获取元素,size-index-1?
7.clear():循环设置元素位置为null然后长度size设为0
8.iterator!!!
LinkedList:链表
Vector:创建的时候初始化容量就是10 和ArrayList的底层结构相同都是Object类型的数组,ArrayList
在add元素的时候才会初始化容量 扩容方式 Arrays扩容每次0.5倍 Vector每次扩容1倍
ArraysList线程非同步(jdk1.2)是Vector(jdk1.0)安全性高线程同步的优化