java之List实现类

本文深入解析了ArrayList和LinkedList两种Java集合类的特点与使用场景。详细介绍了ArrayList的数组结构实现方式,其查询速度快但增删操作较慢的特性,以及Vector作为早期线程安全的ArrayList替代品的优缺点。同时,对比了LinkedList的链表结构,强调了其在增删操作上的优势,但在查询速度上稍逊一筹。通过具体实例展示了如何创建、操作这些集合类。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ArrayList【重点

List接口特点:有序、有下标、元素可重复。

  • 数组结构实现,查询快,增删慢。
  • jdk1.2版本,运行快,线程不安全。
    实例:
import java.util.ArrayList;

public class TestArryList {
    public static void main(String[] args) {

        ArrayList list1=new ArrayList();
        System.out.println(list1.size());

        list1.add("A");
        list1.add("B");
        list1.add("C");
        list1.add("D");
        System.out.println(list1);
        System.out.println(list1.get(2));
        list1.add(2,"K");
        System.out.println(list1.get(2));
        System.out.println(list1);

        list1.clear();  //清除列表中所有元素
        System.out.println(list1);
        System.out.println(list1.size());

    }
}

运行结果:
0
[A, B, C, D]
C
K
[A, B, K, C, D]
[]
0

Vector

  • 数组结构实现,查询快,增删慢。
  • jdk1.0版本,运行慢,线程安全。

LinkedList

  • 链表结构实现,增删快,查询慢。
    实例:
import java.util.LinkedList;

public class TestLinkedlist {
    public static void main(String[] args) {

        LinkedList list2=new LinkedList();
        System.out.println(list2.size());

        list2.add("A");
        list2.add("B");
        list2.add("C");
        list2.add("D");
        list2.add("E");

        System.out.println(list2);
        System.out.println(list2.size());

        System.out.println(list2.get(2));
        list2.addFirst("asd");
        System.out.println(list2.get(0));
        System.out.println(list2);

    }
}

运行:
0
[A, B, C, D, E]
5
C
asd
[asd, A, B, C, D, E]

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值