Java LinkedList工作原理及实现(一)
来源:互联网 发布:易语言数据库怎么用 编辑:程序博客网 时间:2024/06/05 11:36
目录
- 1. 概述
- 2. set和get函数
- 参考资料
1. 概述
以双向链表实现。链表无容量限制,但双向链表本身使用了更多空间,也需要额外的链表指针操作。
按下标访问元素—get(i)/set(i,e) 要悲剧的遍历链表将指针移动到位(如果i>数组大小的一半,会从末尾移起)。
插入、删除元素时修改前后节点的指针即可,但还是要遍历部分链表的指针才能移动到下标所指的位置,只有在链表两头的操作—add(), addFirst(),removeLast()或用iterator()上的remove()能省掉指针的移动。
LinkedList是一个简单的数据结构,与ArrayList不同的是,他是基于链表实现的。
Doubly-linked list implementation of the List and Deque interfaces. Implements all optional list operations, and permits all elements (including null).
LinkedList<String> list = new LinkedList<String>();list.add("语文: 1");list.add("数学: 2");list.add("英语: 3");
结构也相对简单一些,如下图所示:
2. set和get函数
public E set(int index, E element) { checkElementIndex(index); Node<E> x = node(index); E oldVal = x.item; x.item = element; return oldVal;}public E get(int index) {checkElementIndex(index);return node(index).item;}
这两个函数都调用了node
函数,该函数会以O(n/2)的性能去获取一个节点,具体实现如下所示:
Node<E> node(int index) { // assert isElementIndex(index); if (index < (size >> 1)) { Node<E> x = first; for (int i = 0; i < index; i++) x = x.next; return x; } else { Node<E> x = last; for (int i = size - 1; i > index; i--) x = x.prev; return x; }}
就是判断index是在前半区间还是后半区间,如果在前半区间就从head搜索,而在后半区间就从tail搜索。而不是一直从头到尾的搜索。如此设计,将节点访问的复杂度由O(n)变为O(n/2)。
参考资料
LinkedList (Java Platform SE 8)
0 0
- Java LinkedList工作原理及实现(一)
- Java LinkedList工作原理及实现(二)
- Java LinkedList工作原理及实现
- Java集合-LinkedList工作原理及实现
- LinkedList工作原理及实现
- Java HashMap工作原理及实现(一)
- Java LinkedHashMap工作原理及实现(一)
- Java TreeMap工作原理及实现(一)
- Java EnumMap工作原理及实现(一)
- Java CopyOnWriteArrayList工作原理及实现(一)
- Java LinkedList 实现原理及数据接口
- Java LinkedList 实现原理
- Java LinkedList的实现原理及源码解析
- Java LinkedList的实现原理
- java LinkedList实现原理概述
- Java HashMap工作原理及实现
- Java HashMap工作原理及实现
- Java HashMap工作原理及实现
- HttpServlet中的service和doGet的区别
- 给app设置LaunchImage
- [hadoop]HDFS(Hadoop分布式文件系统)(一)
- Android使用DialogFragment创建对话框
- Android线程池使用终结版
- Java LinkedList工作原理及实现(一)
- java 注意线程下的 异常捕获,会跳过sleep(10000)休眠,可能会出现死循环
- CSS3-多栏布局
- call和apply的理解
- pugixml使用总结
- 写给计算机的大学生!
- Monkey的基本命令
- 关于页面展示的时候出现的问题(笔记)
- Oracle 11g export and import