加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 创业 > 正文

java 中ArrayList与LinkedList机能较量

发布时间:2020-12-31 21:49:12 所属栏目:创业 来源:网络整理
导读:java 中ArrayList与LinkedList机能较量 本日看一框架的代码,看到有些 可以行使ArrayList的处所 行使的是 LinkedList,用到的景象是在一个轮回内里举办次序的插入操纵。 众所周知java内里List接口有两个实现ArrayList 和 LinkedList,他们的实现道理别离是c

java 中ArrayList与LinkedList机能较量

本日看一框架的代码,看到有些 可以行使ArrayList的处所 行使的是 LinkedList,用到的景象是在一个轮回内里举办次序的插入操纵。

众所周知java内里List接口有两个实现ArrayList 和 LinkedList,他们的实现道理别离是c说话中先容的数组和链表。

正如进修数据布局时的熟悉,对付插入操纵,链表的布局更高效,缘故起因是可以通过修改节点的指针 就可以完成插入操纵, 而不像数组,

必要把插入位置之后的数组元素依次后移。

可是,现实环境真如上面假想一样吗,下面通过一个简朴的例子实践,看能得出什么结论。

public static void main(String[] args) {
    List<String> arrayList = new ArrayList<String>();
    List<String> linkedList = new LinkedList<String>();
    long time1 = System.currentTimeMillis();
    for(int i = 0; i < 1000000; i++) {
      arrayList.add(new String("abc"));
    }
    long time2 = System.currentTimeMillis();
    for(int i = 0; i < 1000000; i++) {
      linkedList.add(new String("abc"));
    }
    long time3 = System.currentTimeMillis();
    System.out.println("arrayList.insert_time = " + (time2 - time1));
    System.out.println("linkedList.insert_time = " + (time3 - time2));
    long time11 = System.currentTimeMillis();
    for(int i = 0; i < 10000; i++) {
      int random = RandomUtils.nextInt(10000);
      String temp = arrayList.get(random);
    }
    long time12 = System.currentTimeMillis();
    for(int i = 0; i < 10000; i++) {
      int random = RandomUtils.nextInt(10000);
      String temp = linkedList.get(random);
    }
    long time13 = System.currentTimeMillis();
    System.out.println("arrayList.read_time = " + (time12 - time11));
    System.out.println("linkedList.read_time = " + (time13 - time12));
  }

运行功效:

arrayList.insert_time = 188
linkedList.insert_time = 250
arrayList.read_time = 16
linkedList.read_time = 234

通过功效可以看出:无论什么环境,ArrayList越发高效。尤其对付随机读取,数组的服从是链表的14倍之多。

而插入操纵,两者用时相差不多,可是照旧数组的实现服从高一些。

对付个华夏因,细心想想也不难想大白。

当List存储的内容不多时,写入List的最后的元素,ArrayList和LinkedList用时差不多。

可是当List存储的元素个数很大时,通过数组布局实现的ArrayList插入到最后可以通过数组下标很快会见到,可是LinkedList就必要会见每个节点直到找到最后的元素再举办插入操纵,这中操纵步调的耗时是庞大的,以是列表数目越大,LinkedList就越感吃力了。

虽然,对付要求随机插入的场景,这个时辰LinkedList就要比ArrayList得当了。

感激阅读,但愿能辅佐到各人,感谢各人对本站的支持!

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读