在Java中,关于集合框架有这样一个体系结构:
其主要由两个接口派生而出:Collection和Map,然后再衍生出各自的一些实现类(比如Collection接口又被继承与Set和List接口,而他们各自又实现了具体的类)。

今天我就简要分析一下,实现List的两个类(ArrayList和LinkedList),他们的区别是什么,我们在使用过程中有哪些注意事项。

区别

首先最显要的区别就是,他们的底层结构完全不同,ArrayList底层实现是数组,LinkedList底层实现是链表。这也就导致了他们在对数据操作过程中,会有一定的偏差。

首先抛开这两个类不谈。我们先简单的了解一下数据结构中数组结构和链表结构的优缺点:

数组都是连续的,往往在内存中占据的是一段连续的空间,每一个值对应一个编号(索引值),这就方便我们很快的定位到某个具体元素,或者随机访问值。
我们想要在数组中追加元素,方法有很多种,可以在末尾追加,也可以在任意位置追加,这看似很方便,其实却拖慢了效率。
前文说过数组是一段连续的结构,那么我现在想在中间位置加入一个元素,为了其连续性不被破坏,就必须让其后的元素依次向后挪一位,把这个位置空出来,然后才能插入。删除亦是如此。

链表在内存中就不必是连续的,因为他是通过节点来操作的,就像一条链子一样,对于里面的每个元素而言,只用记住自己前面一个位置和后面一个位置的地址值就可以了。这样我们在插入或者删除的时候,就不用整体挪动了,只需要将他对应的前后节点重新赋值就行了。也就是说在链式结构中是没有索引值这个概念的
但这样也就导致了一个问题,就是我们在查找元素的时候就会相对比较麻烦,因为每个元素只知道自己前后的位置,所以如果我们要找一个元素,需要不断的去遍历,直到找到为止。

在Java中亦是如此,简而言之:

ArrayList更适合查找元素,但不适合插入和删除元素
LinkedList更适合插入和删除元素,但不适合查找

可能我们平时在联系的时候感觉不出来差别,但在处理超多数据的时候效果就明显了。下面我举一个小例子验证一下这个比较结论,在同一位置插入300000个元素:

package day_12_10;

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;
import java.util.Random; /**
* @author soberw
* @Classname ListTest
* @Description
* @Date 2021-12-10 8:40
*/
public class ListTest {
public static void main(String[] args) {
System.out.printf("ArrayList插入300000个元素的时间是:%d\n",arrayAdd());
System.out.printf("LinkedList插入300000个元素的时间是:%d\n",linkAdd());
} public static long arrayAdd() {
long start = System.currentTimeMillis();
Random random = new Random();
List<Integer> arr = new ArrayList<>();
//添加一个元素
arr.add(1);
for (int i = 0; i < 300000; i++) {
//在 0 位置添加300000个元素
arr.add(0, random.nextInt(10));
}
long end = System.currentTimeMillis();
return end - start;
} public static long linkAdd() {
long start = System.currentTimeMillis();
Random random = new Random();
List<Integer> link = new LinkedList<>();
//添加一个元素
link.add(1);
for (int i = 0; i < 300000; i++) {
//在 0 位置添加300000个元素
link.add(0, random.nextInt(10));
}
long end = System.currentTimeMillis();
return end - start;
}
}


这时间差一下子就对比出来了。这说明在插入元素方面,LinkedList确实比ArrayList要快许多。

那么在具体情境中,我们还是要根据具体场景去选择使用哪一种。

总结

    1、 Arraylist底层是数组结构,LinkedList底层是链表结构,这导致了他们本质的区别。

    2、随机访问和查找元素ArrayList要优于LinkedList

    3、添加和删除元素LinkedList要优于ArrayList

文中有什么遗漏的点或者说得不对的地方,欢迎评论区指出,大家一起探讨学习。

浅谈Java中linkedlist和arraylist区别的更多相关文章

  1. 浅谈JAVA中HashMap、ArrayList、StringBuilder等的扩容机制

    JAVA中的部分需要扩容的内容总结如下:第一部分: HashMap<String, String> hmap=new HashMap<>(); HashSet<Strin ...

  2. 浅谈java中的"=="和eqals区别

    在初学Java时,可能会经常碰到下面的代码: 1 String str1 = new String("hello"); 2 String str2 = new String(&qu ...

  3. 浅谈java中==与equals的区别

    今天做了一个业务模块,需要简单的遍历比较值,所以习惯性的用了 "==" ,但是结果没有达到预想的结果是什么鬼? 看到这里,有人一定会指出这俩货不是基本变量! "关系操作符 ...

  4. 浅谈Java中set.map.List的区别

    就学习经验,浅谈Java中的Set,List,Map的区别,对JAVA的集合的理解是想对于数组: 数组是大小固定的,并且同一个数组只能存放类型一样的数据(基本类型/引用类型),JAVA集合可以存储和操 ...

  5. Java基础学习总结(29)——浅谈Java中的Set、List、Map的区别

    就学习经验,浅谈Java中的Set,List,Map的区别,对JAVA的集合的理解是想对于数组: 数组是大小固定的,并且同一个数组只能存放类型一样的数据(基本类型/引用类型),JAVA集合可以存储和操 ...

  6. 浅谈Java中的equals和==(转)

    浅谈Java中的equals和== 在初学Java时,可能会经常碰到下面的代码: 1 String str1 = new String("hello"); 2 String str ...

  7. 浅谈Java中的对象和引用

    浅谈Java中的对象和对象引用 在Java中,有一组名词经常一起出现,它们就是“对象和对象引用”,很多朋友在初学Java的时候可能经常会混淆这2个概念,觉得它们是一回事,事实上则不然.今天我们就来一起 ...

  8. 浅谈Java中的equals和==

    浅谈Java中的equals和== 在初学Java时,可能会经常碰到下面的代码: String str1 = new String("hello"); String str2 = ...

  9. 浅谈Java中的深拷贝和浅拷贝(转载)

    浅谈Java中的深拷贝和浅拷贝(转载) 原文链接: http://blog.csdn.net/tounaobun/article/details/8491392 假如说你想复制一个简单变量.很简单: ...

随机推荐

  1. js 简单版发布留言 案例

    <!DOCTYPE html>   <html lang="en">   <head>       <meta charset=" ...

  2. java 线程 总结

    1.前言 (1)线程的上一级是进程,进程是程序的一次执行过程,是系统运行程序的基本单位,因此进程是动态的. (2)线程与进程相似,但线程是一个比进程更小的执行单位,也被称为轻量级进程.一个进程在其执行 ...

  3. 新建koa2项目

    1.npm install -g koa-generator 2.koa2 项目名称,如果需要ejs引擎koa2 -e 项目名称 3.cd 项目名称 4.npm install 5.npm insta ...

  4. Mysql高性能优化

    一.背景 最近公司项目添加新功能,上线后发现有些功能的列表查询时间很久.原因是新功能用到旧功能的接口,而这些旧接口的 SQL 查询语句关联5,6张表且编写不够规范,导致 MySQL 在执行 SQL 语 ...

  5. Maven+ajax+SSM实现查询

    2.尚硅谷_SSM高级整合_使用ajax操作实现页面的查询功能 16.尚硅谷_SSM高级整合_查询_返回分页的json数据.avi 在上一章节的操作中我们是将PageInfo对象存储在request域 ...

  6. springboot应用中使用CommandLineRunner

    在springboot应用中,存在这样的使用场景,在springboot ioc容器创建好之后根据业务需求先执行一些操作,springboot提供了两个接口可以实现该功能: CommandLineRu ...

  7. 《剑指offer》面试题09. 用两个栈实现队列

    问题描述 用两个栈实现一个队列.队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能.(若队列中没有元素,dele ...

  8. Docsify部署IIS

    什么是Docsify? 一个神奇的文档网站生成器.docsify 可以快速帮你生成文档网站.不同于 GitBook.Hexo 的地方是它不会生成静态的 .html 文件,所有转换工作都是在运行时.如果 ...

  9. numpy中,从一片c_void_p指向的区域里获取数据

    以前采用的数据拷贝的笨办法: 1 bitmap_size = (1080, 1920, 3) 2 buf = create_string_buffer(bitmap_size[0]*bitmap_si ...

  10. 多线程创建的方式一(继承Thread类)

    1 package multithread; 2 3 /* 4 * 如何创建一个线程呢? 5 * 6 * 创建线程方式一:继承Thread类. 7 * 8 * 步骤: 9 * 1,定义一个类继承Thr ...