1经典问题答案记录-ArrayList和LinkedList的区别

经典问题答案记录-ArrayList和LinkedList的区别

  1. ArrayList的实现是基于数组来实现的,LinkedList的基于双向链表来实现。这两个数据结构的逻辑关系是不一样,当然物理存储的方式也会是不一样。

  2. LinkedList比ArrayList更占内存,因为LinkedList的节点除了存储数据,还存储了两个引用,一个指向前一个元素,一个指向后一个元素。

  3. 对于随机访问(获取某一某些元素),ArrayList要优于LinkedList。

  4. 对于插入和删除操作,LinkedList优于ArrayList。

package com.jvm.memory.testDemo;

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

public class CompareListThird {


        public static int max = 100000;//测试元素数

        public static void main(String[] args) {
            // TODO Auto-generated method stub


            ArrayList<Object> arrList = new ArrayList<Object>();
            LinkedList<Object> linList = new LinkedList<Object>();

            System.out.println("测试元素数:" + max);
            System.out.println("ArrayList插入消耗的时间:" + insertTime(arrList) + "ms");
            System.out.println("LinkedList插入消耗的时间:" + insertTime(linList) + "ms");

            System.out.println("\nArrayList访问消耗的时间:" + getTime(arrList) + "ms");
            System.out.println("LinkedList访问消耗的时间:" + getTime(linList) + "ms");

            System.out.println("\nArrayList删除消耗的时间:" + delTime_v2(arrList) + "ms");
            System.out.println("LinkedList删除消耗的时间:" + delTime_v2(linList) + "ms");

        }

        public static long insertTime(List list) {
            long time = System.currentTimeMillis();
            for (int i = 0; i < max; i++) {
                list.add(i); // 逐个插入 max 个元素
            }
            return System.currentTimeMillis() - time;
        }

        public static long getTime(List list) {
            long time = System.currentTimeMillis();
            for (int i = 0; i < max; i++) {
                int index = Collections.binarySearch(list, list.get(i));
                if (index != i) {
                    System.out.println("ERROR!");
                }
            }
            return System.currentTimeMillis() - time;
        }

        public static long delTime_v2(List list) {
            long time = System.currentTimeMillis();

            while (checkListSize(list)) {
                if (list instanceof LinkedList) {
                    ((LinkedList) list).removeFirst();
                } else if (list instanceof ArrayList) {
                    list.remove(0);
                }
            }

            return System.currentTimeMillis() - time;
        }

        public static boolean checkListSize(List list) {
            if (list.size() <= 0)
                return false;
            else
                return true;
        }



}

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值