List

一、概述

上层接口是Collection,有索引,可以重复存储
下层接口有3个子类,分别是ArrayList,Vector,LinkedList

二、子类比较

ArrayList:
底层是数组,查询修改快,增加删除慢
线程不安全,但效率高
Vector:
底层是数组,查询修改快,增加删除慢
线程安全,但效率低
LinkedList:
底层是链表,查询修改慢,增加删除快
线程不安全,但效率高

三、List集合特有的方法

void add(int index,E element)
E remove(int index)
E get(int index)
E set(int index,E element)
可以发现:多了索引

四、List集合的遍历

方法一:通过size()和get()方法
案列演示:

List list = new ArrayList();     //父类引用指向子类对象
            list.add(new Student("张三", 23));
            list.add(new Student("李四", 24));
            list.add(new Student("王五", 25));
            list.add(new Student("赵六", 26);
            
            for(int i = 0; i < list.size(); i++) { 
               // System.out.println(list.get(i));      返回指定位置的元素
                Student s = (Student)list.get(i);      //强转成Student对象
                System.out.println(s.getName() + "," + s.getAge());
            }

方法二:通过迭代器迭代

Iterator <Student>it=list.iterator();   //使用了泛型
while(it.hasNext()){
    System.out.println(it.next());
}

方法三:使用增强for循环-内部使用的其实仍然是迭代

for(Student s:list){
     System.out.println(s);
}      
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值