java List ArrayList

本文详细解析了List和ArrayList的区别,包括它们之间的继承关系、构造方式、属性方法等,并探讨了在不同场景下如何选择合适的集合类,强调了使用List接口的好处,即能够灵活地切换不同的集合实现类而不修改现有代码。

List是一个接口,而ListArray是一个类。
ListArray继承并实现了List。
所以List不能被构造,但可以向上面那样为List创建一个引用,而ListArray就可以被构造。
List list;     //正确   list=null;
List list=new List();    //   是错误的用法

 

List list = new ArrayList();这句创建了一个ArrayList的对象后把上溯到了List。此时它是一个List对象了,有些ArrayList有但是List没有的属性和方法,它就不能再用了。
而ArrayList list=new ArrayList();创建一对象则保留了ArrayList的所有属性。
这是一个例子:
import java.util.*;

public class TestList{
public static void main(String[] args){
List list = new ArrayList();
ArrayList arrayList = new ArrayList();

list.trimToSize(); //错误,没有该方法。
arrayList.trimToSize();   //ArrayList里有该方法。
}
}

编译一下就知道结果了。

如果这个样子:
List a=new ArrayList();
则a拥有List与ArrayList的所有属性和方法,不会减少
如果List与ArrayList中有相同的属性(如int i),有相同的方法(如void f()),
则a.i是调用了List中的i
a.f()是调用了ArrayList中的f();
---------------------------------------------------------------
问题的关键:
为什么要用 List list = new ArrayList() ,而不用 ArrayList alist = new ArrayList()呢?
问题就在于List有多个实现类,现在你用的是ArrayList,也许哪一天你需要换成其它的实现类,如 LinkedList或者Vector等等,这时你只要改变这一行就行了:
List list = new LinkedList(); 其它使用了list地方的代码根本不需要改动。
假设你开始用 ArrayList alist = new ArrayList(), 这下你有的改了,特别是如果你使用了 ArrayList特有的方法和属性。


地区用 List arr = new ArrayList();定义;行业用 ArrayListarr = new ArrayList();定义;则说明,行业里用到了ArrayList的特殊的方法.

另外的例子就是,在类的方法中,如下声明:
private void doMyAction(List list){}
这样这个方法能处理所有实现了List接口的类,一定程度上实现了泛型函数.

如果开发的时候觉得ArrayList,HashMap的性能不能满足你的需要,可以通过实现List,Map(或者Collection)来定制你的自定义类.


JavaArrayList和LinkedList存在多方面的区别: - **基本结构**:ArrayList基于数组实现,元素在内存中连续存储;LinkedList基于链表实现,元素在内存中非连续存储,每个元素存储了指向其前一个和后一个元素的指针[^5]。 - **性能表现**: - **随机访问**:ArrayList性能通常优于LinkedList。因为ArrayList可直接通过索引访问数组中的元素;而LinkedList需从头节点或尾节点开始遍历[^4]。 - **插入和删除操作**:LinkedList通常优于ArrayList,特别是在列表中间位置操作时。LinkedList插入和删除操作只需改变相邻节点的引用,无需移动其他元素;ArrayList插入或删除元素时可能需移动大量元素[^4]。 - **方法特性**:LinkedList的方法和使用与ArrayList大致相同,但由于是链表实现,额外提供了在头部和尾部添加/删除元素的方法,且没有ArrayList扩容的问题[^3]。 - **数据结构实现**:ArrayList和LinkedList都能实现栈、队列等数据结构,但LinkedList本身实现了队列的接口,所以更推荐用它来实现队列和栈[^3]。 ### 示例代码 ```java import java.util.ArrayList; import java.util.LinkedList; import java.util.List; public class ListExample { public static void main(String[] args) { // 创建ArrayList List<String> arrayList = new ArrayList<>(); arrayList.add("element1"); arrayList.add("element2"); System.out.println("ArrayList: " + arrayList); // 创建LinkedList List<String> linkedList = new LinkedList<>(); linkedList.add("element3"); linkedList.add("element4"); System.out.println("LinkedList: " + linkedList); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值