当前位置: 首页 > news >正文

河源市住房和城乡规划建设局网站现在1做啥网站流量大

河源市住房和城乡规划建设局网站,现在1做啥网站流量大,网站建设不要摸板,网站推广效果的评价指标有LinkedList在Java中是一个实现了List和Deque接口的双向链表。它允许我们在列表的两端添加或删除元素,同时也支持在列表中间插入或移除元素。在分析LinkedList之前,需要理解链表这种数据结构: 链表:链表是一种动态数据结构&#x…

LinkedList在Java中是一个实现了ListDeque接口的双向链表。它允许我们在列表的两端添加或删除元素,同时也支持在列表中间插入或移除元素。在分析LinkedList之前,需要理解链表这种数据结构:

  • 链表:链表是一种动态数据结构,由一系列节点组成,每个节点包含数据部分和指向列表中下一个节点的引用。
  • 双向链表:每个节点都有两个链接,一个指向前一个节点,另一个指向后一个节点。

LinkedList 的数据结构

LinkedList中,每个元素都是一个节点,每个节点包含三个部分:存储的数据项、指向前一个节点的引用和指向后一个节点的引用。

private static class Node<E> {E item; // 存储的数据Node<E> next; // 指向后一个节点的引用Node<E> prev; // 指向前一个节点的引用Node(Node<E> prev, E element, Node<E> next) {this.item = element;this.next = next;this.prev = prev;}
}

LinkedList 的核心方法

LinkedList实现了List接口,所以它具有诸如add, remove, get, set等方法,同时也实现了Deque接口,这意味着它也具有offer, poll, push, pop等方法。

源码解析(简化版)

以下是LinkedList中一些关键方法的简化版源码:

public class LinkedList<E>extends AbstractSequentialList<E>implements List<E>, Deque<E>, Cloneable, java.io.Serializable {transient int size = 0;transient Node<E> first;transient Node<E> last;public LinkedList() {}public boolean add(E e) {linkLast(e);return true;}void linkLast(E e) {final Node<E> l = last;final Node<E> newNode = new Node<>(l, e, null);last = newNode;if (l == null)first = newNode;elsel.next = newNode;size++;modCount++;}public E remove() {return unlinkFirst(first);}private E unlinkFirst(Node<E> f) {final E element = f.item;final Node<E> next = f.next;f.item = null;f.next = null; first = next;if (next == null)last = null;elsenext.prev = null;size--;modCount++;return element;}public E get(int index) {checkElementIndex(index);return node(index).item;}Node<E> node(int 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;}}// 省略其他细节实现
}

代码演示

下面是LinkedList的一个简单使用示例:

import java.util.LinkedList;public class Main {public static void main(String[] args) {LinkedList<String> friends = new LinkedList<>();// 添加元素friends.add("Alice");friends.add("Bob");friends.add("Charlie");// 打印所有元素System.out.println("Initial LinkedList: " + friends);// 删除第一个元素friends.remove();// 打印删除元素后的列表System.out.println("After removal: " + friends);// 获取特定位置的元素String friend = friends.get(1);System.out.println("Second friend: " + friend);}
}

细节分析

使用LinkedList时,有几个细节需要注意:

  • 动态扩展:由于LinkedList是基于节点的,因此它可以动态地添加或删除节点而不需要像数组那样重新分配整个数据结构。
  • 随机访问效率低:获取特定索引的元素时,LinkedList必须从头开始(或从尾开始,取决于哪边更近)遍历节点。因此,随机访问的效率远低于数组。
  • 插入和删除效率高:在任何位置插入或删除元素时,LinkedList只需要改变几个引用,这使得插入和删除操作非常快速。
  • 内存开销:与数组相比,LinkedList的每个元素都需要额外的内存空间来存储前后节点的引用。

通过以上解析,我们可以深入理解LinkedList的工作原理和设计。这有助于开发者在需要适合的数据结构时作出明智的选择。对于需要频繁插入和删除操作的场景,LinkedList可能是一个不错的选择。然而,如果需要快速通过索引访问元素,那么ArrayList可能是更好的选择。

http://www.yayakq.cn/news/101422/

相关文章:

  • 专业微网站电话号码宿州企业官方网站建设
  • 南昌p2p网站建设计算机前端开发要学哪些软件
  • 学院网站板块本地wordpress 手机浏览器
  • 十堰城市建设网站班服定制的网站
  • 网站建设哪公司网站定制开发流程
  • 旅游 便宜 网站建设做拍卖网站有哪些
  • 网站建设 招聘计算机网站建设方向
  • 网站设计就业压力大型公司网站建设
  • 网站建设收费标准服务北京网站建设公司哪家实惠
  • asp网站开发 基础一个网站 两个域名
  • 成都网站只wordpress翻译了 mo无效
  • 网站开发人才广东建设职业技术学院网站
  • wordpress网站怎么设置关键词尚海整装公司电话
  • 网站到期了广州网站开发多少钱
  • 网站建设公司优势建设网站几钱
  • 做网站鼠标移动 链接变颜色wordpress内置分页方法
  • 房屋中介网站模板wordpress++xml
  • 网站备案 域名过期网站建设需要的技术设备
  • 个人网站开发教程网站哪些功能是PHP做的
  • 个人网站首页布局图安徽做网站公司
  • 手把手教你做网站 3云主机和云服务器的区别
  • 建设校园网站国外研究现状品牌查询网站
  • 国内知名网站建设排名wordpress 底部版权
  • 网站诊断内容wordpress 评论调用
  • 网站虚拟空间购买怎样做无水印视频网站
  • 滁州市南谯区建设局网站做慕斯蛋糕那个网站有视频
  • 如何做网站拓扑结构图在线营销型网站制作
  • 搜索引擎优化网站中国搜索引擎排名2021
  • 福州云建站惠州网站建设电话
  • 网站项目建设方案文档怎么在自己电脑做网站