一、List接口有三个常用的集合(ArrayList、Vector、LinkedList)

ArrayList注意事项

  • ArrayList底层是用数组来实现数据存储的 底层是 transient Object[ ] elementdata  是一个Object类型的数组
  • 这个  transient 意思是:短暂的,瞬间的 用这个关键字修饰表示 该属性不会序列化,解释:有些属性不需要被序列化,比如一些敏感的信息,银行卡密码等,一些隐私,可以用transient
  • ArrayList基本等同于Vector,ArrayList是线程不安全的,但效率高,在多线程的情况下,不建议使用ArrayList

ArrayList的源码分析

  • ArrayList底层是一个数组
  • ArrayList有两个构造器:1、一个是无参的。     2、一个是有参的构造器传入一个int类型的值,指定ArrayList数组的大小
  • 当创建ArrayList对象时,调用无参构造器,则初始化数组大小为10  也就是把 elementdata 初始化 = 10。 当添加到第11个的时候,会对数组进行扩容, 会按照 elementdata 的1.5倍扩容。 如果15个空间用完,则会以15的1.5倍扩容。从此类推,如果没给值,默认的就是null。
  • 当创建ArrayList对象时,调用有参构造器,会传入一个int值,指定数组大小。假设传入的是8,则 elementdata = 8 如果超过8个,就扩容,则是 8的1.5倍。类推,没有数据默认为null。

Vector

  • Vector底层也是一个对象数组
  • Vector底层和Arraylist几乎相同,就是一个线程安全,一个线程不安全
  • Vector是线程同步的,即线程安全,Vector操作方法有Synchoronized
  • public synchronized boolean add(E e) {
    modCount++;
    ensureCapacityHelper(elementCount + 1);
    elementData[elementCount++] = e;
    return true;
    }

ArrayList和Vector的区别

LinkedList介绍

  • LinkedList底层维护了一个双向链表
  • 可以添加任何元素,元素可以重复,包括null
  • 线程不安全,没有实现同步

 LinkedList的底层分析

  • LinkedList 是一个继承于AbstractSequentialList的双向链表。它也可以被当作堆栈、队列或双端队列进行操作。 

  • LinkedList中维护了两个属性:一个是first和last分别指向首届点和尾节点
  • 每一个节点里面有一个Node对象,里面有维护了prev,next,item三个属性,其中通过prev指向指向前一个节点,通过next指向后一个节点。最终实现双向链表
  • 所以LInkedList的元素添加和删除,不是通过数组完成的,相对来说效率比较高

ArrayList和LinkedList区别

java中的List接口(ArrayList、Vector、LinkedList)的更多相关文章

  1. java中集合类HashSet、ArrayList、LinkedList总结

    [HashSet] 1. HashSet存储不能够存储相同的元素,元素是否相同的判断:重写元素的equals方法.equals方法和hashCode方法必须兼容,如:equals方法判断的是用户的名字 ...

  2. Java中的List接口实现类LinkedList

    package collection; import java.util.LinkedList; /* * 1.implement List接口 * 2.底层是一个链表结构:查询慢,增删快 * 注意: ...

  3. ArrayList Vector LinkedList(一)

    ArrayList Vector LinkedList 区别与用法 ArrayList 和Vector是采用数组方式存储数据,此数组元素数大于实际存储的数据以便增加和插入元素,都允许直接序号索引元素, ...

  4. Java 中的集合接口——List、Set、Map

    Java 中的集合接口——List.Set.Map 什么叫集合:集合就是Java API所提供的一系列类的实例,可以用于动态存放多个对象.这跟我们学过的数组差不多,那为什么我们还要学集合,我们看看数组 ...

  5. java基础解析系列(十)---ArrayList和LinkedList源码及使用分析

    java基础解析系列(十)---ArrayList和LinkedList源码及使用分析 目录 java基础解析系列(一)---String.StringBuffer.StringBuilder jav ...

  6. 用好JAVA中的函数式接口,轻松从通用代码框架中剥离掉业务定制逻辑

    大家好,又见面了. 今天我们一起聊一聊JAVA中的函数式接口.那我们首先要知道啥是函数式接口.它和JAVA中普通的接口有啥区别?其实函数式接口也是一个Interface类,是一种比较特殊的接口类,这个 ...

  7. paip.提升性能---list,arraylist,vector,linkedlist,map的选用..

    paip.提升性能---list,arraylist,vector,linkedlist,map的选用.. arraylist,vector基本一样,但是,vector线程安全的. 作者Attilax ...

  8. 转:二十一、详细解析Java中抽象类和接口的区别

    转:二十一.详细解析Java中抽象类和接口的区别 http://blog.csdn.net/liujun13579/article/details/7737670 在Java语言中, abstract ...

  9. 关于JAVA中抽象类和接口的区别辨析

    今天主要整理一下新学习的有关于Java中抽象类和接口的相关知识和个人理解. 1 抽象类 用来描述事物的一般状态和行为,然后在其子类中去实现这些状态和行为.也就是说,抽象类中的方法,需要在子类中进行重写 ...

随机推荐

  1. ApacheCN Pandas 教程集

    Pandas 秘籍 零.前言 一.Pandas 基础 二.数据帧基本操作 三.开始数据分析 四.选择数据子集 五.布尔索引 六.索引对齐 七.分组以进行汇总,过滤和转换 八.将数据重组为整齐的表格 九 ...

  2. C语言设计ATM存取款界面

    这个虽然很简单,但是我还是弄了一会儿,可见有多菜.练习算. 主要考察switch开关语句.do...while语句,页面的跳转我用的是goto,虽然是弊端,可是还是用了,因为太菜啊.大家有好建议的欢迎 ...

  3. JAVA String介绍、常量池及String、StringBuilder和StringBuffer得区别. 以及8种基本类型的包装类和常量池得简单介绍

    一.概述 String是代表字符串的类,本身是一个最终类,使用final修饰,不能被继承. 二.定义方式   方式一:直接赋值法 String str1 = "hello"; 方式 ...

  4. go基础——if语法

    package main import "fmt" /* 条件语句:if 注意点: 1.if后的{,要与if条件写在同一行: 2.else要跟在}之后,不能另起一行: 3.if和e ...

  5. Nodejs允许跨域访问

    状况:本地的前端项目(uni-app)以及后台管理(vue-mongo-node)和本地mongo数据库 前台项目端口是8082,后台数据接口是8081. 跨域解决,直接上代码: uni-app的ma ...

  6. 模型融合——stacking原理与实现

    一般提升模型效果从两个大的方面入手 数据层面:数据增强.特征工程等 模型层面:调参,模型融合 模型融合:通过融合多个不同的模型,可能提升机器学习的性能.这一方法在各种机器学习比赛中广泛应用, 也是在比 ...

  7. sbt修改源(国内优先)

    [repositories] local aliyun: https://maven.aliyun.com/repository/public oschina: http://maven.oschin ...

  8. SQL 在数据库中查找拥有此列名的所有表

    SELECT TABLE_NAME FROM INFORMATION_SCHEMA.COLUMNS WHERE COLUMN_NAME='Column' #"Column"为要查询 ...

  9. Solution -「AGC 016F」Games on DAG

    \(\mathcal{Description}\)   Link.   给定一个含 \(n\) 个点 \(m\) 条边的 DAG,有两枚初始在 1 号点和 2 号点的棋子.两人博弈,轮流移动其中一枚棋 ...

  10. macbook安装scala、hadoop、saprk环境

    一.scala安装 1. 安装jdk 有mac专用的jdk安装包,这里下载安装jdk1.8 2. 安装scala 2.1下载scala 2.2解压到指定目录 tar -zxvf /Users/lode ...