java集合框架 知识点3.ArrayList和LinkedList的区别

这篇博客探讨了ArrayList和LinkedList两种Java集合在查找定位、插入删除操作上的性能差异。ArrayList作为顺序结构,查找定位速度快,但插入删除慢,需要移动大量元素。LinkedList则相反,查找定位慢,但插入删除快,因为仅需更改相邻元素的引用。实验结果显示,在特定操作中,ArrayList的耗时远低于LinkedList。

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

1.查找定位

ArrayList是顺序结构,指哪找哪。 学生站排每个人手中都有自己的号码牌,想找几号几号就可以出来。所以查找定位很快
LinkedList 是链表结构,就像学生站排,每个人只是知道自己后面的人是谁,要是先找到100号学生,要从1号顺到2号……直到找到100号。查找定位很慢

import java.util.ArrayList;
import java.util.Collections;
import java.util.LinkedList;
import java.util.List;

public class demo {

	public static void main(String[] args) {
	        List<Integer> l;
	        l = new ArrayList<>();
	        modify(l, "ArrayList");
	 
	        l = new LinkedList<>();
	        modify(l, "LinkedList");
	 
	    }
	 
	    private static void modify(List<Integer> l, String type) {
	        int total = 100 * 1000;
	        int index = total/2;
	        final int number = 5;
	        //初始化
	        for (int i = 0; i < total; i++) {
	            l.add(number);
	        }
	         
	        long start = System.currentTimeMillis();
	 
	        for (int i = 0; i < total; i++) {
	             int n = l.get(index);
	             n++;
	             l.set(index, n);
	        }
	        long end = System.currentTimeMillis();
	        System.out.printf("%s总长度是%d,定位到第%d个数据,取出来,加1,再放回去%n 重复%d遍,总共耗时 %d 毫秒 %n", type,total, index,total, end - start);
	        System.out.println();
	    }
}

ArrayList总长度是100000,定位到第50000个数据,取出来,加1,再放回去
 重复100000遍,总共耗时 6 毫秒 

LinkedList总长度是100000,定位到第50000个数据,取出来,加1,再放回去
 重复100000遍,总共耗时 21340 毫秒 

2.插入删除

ArrayList 插入,删除数据慢

每个人有自己的号码牌,如果想插入一个元素,例如:10个人站排每个人都有自己的号码牌,现在想在索引值为1的位置插入一个人,此时需要吧1的号牌给插入的人,而原来位置的人要去拿2号号牌,原来二号的人要去拿3号的号牌,以此类推,后面的人都要更换手中的好牌。

LinkedList, 插入,删除数据快。

还是十个人每个人知道自己前后是谁,此时查入一个人,只需改变插入位置处,前一个人和后一个人的数值即刻。其他人的相对位置不变,所以不需要更改。

import java.util.ArrayList;
import java.util.Collections;
import java.util.LinkedList;
import java.util.List;

public class demo {

	public static void main(String[] args) {
		List<Integer> l;
		
        l = new ArrayList<>();//新建数组列表
        insertFirst(l, "ArrayList");
 
        l = new LinkedList<>();//新建链表
        insertFirst(l, "LinkedList");
 
    }
 
    private static void insertFirst(List<Integer> l, String type) {
        int total = 1000 * 100;
        final int number = 5;
        long start = System.currentTimeMillis();//获取开始当前时间
        for (int i = 0; i < total; i++) {
            l.add(0, number);
        }
        long end = System.currentTimeMillis();//获取当前结束时间
        System.out.printf("在%s 最前面插入%d条数据,总共耗时 %d 毫秒 %n", type, total, end - start);
    }
}
在ArrayList 最前面插入100000条数据,总共耗时 596 毫秒 
在LinkedList 最前面插入100000条数据,总共耗时 6 毫秒 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值