Java ArrayList与LinkedList区别

1、区别
ArrayList 插入,删除数据慢
LinkedList, 插入,删除数据快
ArrayList是顺序结构,所以定位很快,指哪找哪。 就像电影院位置一样,有了电影票,一下就找到位置了。
LinkedList 是链表结构,就像手里的一串佛珠,要找出第99个佛珠,必须得一个一个的数过去,所以定位慢
2、插入数据

private static void insertData() {
		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();
//        %s-->String   %d -->int
        System.out.printf("在%s 最前面插入%d条数据,总共耗时 %d毫秒 \n", type, total, end - start);
		
	}

在这里插入图片描述
3、定位数据

private static void getData() {
		// TODO Auto-generated method stub
		List<Integer> l;
        l = new ArrayList<>();
        modify(l, "ArrayList");
 
        l = new LinkedList<>();
        modify(l, "LinkedList");
	}

	private static void modify(List<Integer> l, String string) {
		 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.add(index, n);
	        }
	        long end = System.currentTimeMillis();
	        System.out.printf("%s总长度是%d,定位到第%d个数据,取出来,加1,再放回去%n 重复%d遍,总共耗时 %d 毫秒 %n", string,total, index,total, end - start);
	        System.out.println();
	}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值