一. ArrayList底层实现原理 对比 和Vector不同,ArrayList中的操作不是线程安全的!所以,建议在单线程中才使用ArrayList,而在多线程中可以选择Vector或者CopyOnWriteArrayList. 总结:(01) ArrayList 实际上是通过一个数组去保存数据的.当我们构造ArrayList时:若使用默认构造函数,则ArrayList的默认容量大小是10.(02) 当ArrayList容量不足以容纳全部元素时,ArrayList会重新设置容量:新的容量=“(…
链表 链表是一种物理存储单元上非连续.非顺序的存储结构,数据元素的逻辑顺序是通过链表中的指针链接次序实现的. 链表由一系列结点(链表中每一个元素称为结点)组成,结点可以在运行时动态生成.每个结点包括两个部分:一个是存储数据元素的数据域,另一个是存储下一个结点地址的指针域. 由于不必须按顺序存储,链表在插入的时候可以达到O(1)的复杂度. 与数组相比 优点: 插入数据快 不需要预先知道数据大小 可以充分利用计算机内存空间 缺点: 随机读取速度慢,寻址花时间 空间开销比较大,因为增加了结点的指针域…
上文里解析了有关ArrayList中的几个常用方法的源码——<有关ArrayList常用方法的源码解析>,本文将对LinkedList的常用方法做简要解析. LinkedList是基于链表实现的,也就是说它具备了链表的优点和缺点,随机访问慢.插入删除速度快.既然是链表,那么它就存在节点数据结构,也不存在容量大小的问题,来一个在尾部添加一个. //LinkedList$Node private static class Node<E> { E item; Node<E>…
LinkedList是常用的集合结构之一,数据存储结构为链式存储,每个节点都有元素.前指针和后指针,指针指向了前节点和后节点的位置.同是LinkedList也是一个队列,实现了Deque接口,Deque接口继承了Queue接口. 1.7以前为双向循环链表,之后没有循环了哦. 队列出入顺序为FIFO,插入的位置是队列的尾部,而移出的位置是队头,Queue接口提供了offer()入列,和poll()出列的方法. LinkedList的add(E e)方法: public boolean add(E…
集合使用注意事项: 1.集合当中只能放置对象的引用,无法放置原生数据类型,我们需要使用原生数据类型的包装类才能加入到集合当中去(JDK5之后会进行自动的装箱和拆箱操作,表面上看集合中是可以直接放置原生数据类型进去,但实质上是进过自动装箱成对象操作的): 2.集合当中放置的都是Object类型,因此取出来的也是Object类型(可以放置任意类型的数据),那么必须要使用强制类型转换将其转换为真正的类型(放置进去的类型). ArrayList ArrayList常用方法: boolean add(E…
本文参考资料: 1.<大话数据结构> 2.http://blog.csdn.net/jzhf2012/article/details/8540543 3.http://blog.csdn.net/jzhf2012/article/details/8540410 4.http://www.cnblogs.com/ITtangtang/p/3948610.html 5.http://blog.csdn.net/zw0283/article/details/51132161 本来在分析完HashSe…
1.LinkedList实现的基本原理 LinkedList是一个双向链表,它主要有两个表示头尾节点的成员变量first  .last,因其有头尾两个节点,所以从头或从尾操作数据都非常容易快捷.LinkedList通过内部类Node来保存元素 ,一个Node对象表示链表的一个节点,有多少个元素就需要多少个Node节点.如果要添加元素,则新建一个Node节点,保存这个元素,同时指定其前驱节点和后继节点的引用.若要删除一个元素,则将取消此元素对应的Node节点在链表中的前驱后继关系. 2.Liste…
由于转行的原因,最近打算开始好好学习,昨天看到了部分的LinkedList源码,并且看了一点数据结构的视频,现总结部分自己的心得体会,以供后期给现在的自己拍砖~ 双向链表每一个元素都有数据本身加指向前一个元素的属性与指向后一个元素的属性. 下面对Java中LinkedList部分源码进行个人理解的分享: LinkedList定义大小和头尾节点,构造方法. 定义Node节点,节点有三个属性,元素和前后指向. 添加: 125:在头节点之前新增元素的方法 126:将首节点赋值给f变量 127:用构造函…
序言 LinkedList是一个双向链表 也就是说list中的每个元素,在存储自身值之外,还 额外存储了其前一个和后一个元素的地址,所以也就可以很方便地根据当前元素获取到其前后的元素 链表的尾部元素的后一个节点是链表的头节点:而链表的头结点前一个节点则是则是链表的尾节点(是不是有点像贪吃蛇最后 头吃到自己尾巴的样子,脑补下) 既然是一个双向链表,那么必然有一个基本的存储单元,让我们来看LinkedList的最基础的存储单元. 源码 Node private static class Node<E…
Java集合 LinkedList的原理及使用 LinkedList和ArrayList一样是集合List的实现类,虽然较之ArrayList,其使用场景并不多,但同样有用到的时候,那么接下来,我们来认识一下它. 一. 定义一个LinkedList public static void main(String[] args) { List<String> stringList = new LinkedList<>(); List<String> tempList = n…