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

网站做302跳转的意义网店推广网站

网站做302跳转的意义,网店推广网站,东莞网站建设在哪里,保定网站seo服务目录 1. 数据结构 2. 性能特点 3. 源码分析 4. 代码演示 5. 细节和使用场景 ArrayList 和 LinkedList 分别代表了两类不同的数据结构:动态数组和链表。它们都实现了 Java 的 List 接口,但是有着各自独特的特点和性能表现。 1. 数据结构 ArrayList…

目录

1. 数据结构

2. 性能特点

3. 源码分析

4. 代码演示

5. 细节和使用场景


ArrayListLinkedList 分别代表了两类不同的数据结构:动态数组和链表。它们都实现了 Java 的 List 接口,但是有着各自独特的特点和性能表现。

1. 数据结构

  • ArrayList 是基于可调整大小的数组实现的。它允许快速随机访问,因为内部元素可通过数组索引直接访问。
  • LinkedList 是基于双向链表实现的。链表中的每个元素都包含了对其前一个和后一个元素的引用,允许双向遍历。

2. 性能特点

特性/操作ArrayListLinkedList
随机访问O(1)O(n)
添加元素(一般)O(1) (摊销时间)O(1)
在末尾添加元素O(1) (摊销时间)O(1)
在中间/开始添加元素O(n)O(1)
删除元素(一般)O(n)O(1)
内存开销较小 (只存数据)较大 (数据 + 两个引用)

3. 源码分析

  • ArrayList 源码关键部分
public class ArrayList<E> extends AbstractList<E> implements List<E>, RandomAccess, Cloneable, java.io.Serializable {transient Object[] elementData; // 存储数据private void ensureCapacityInternal(int minCapacity) {if (elementData == DEFAULTCAPACITY_EMPTY_ELEMENTDATA) {minCapacity = Math.max(DEFAULT_CAPACITY, minCapacity);}if (minCapacity - elementData.length > 0) {grow(minCapacity);}}private void grow(int minCapacity) {// 扩容逻辑}public E get(int index) {rangeCheck(index);return elementData[index];}public boolean add(E e) {ensureCapacityInternal(size + 1);  // 确保容量elementData[size++] = e;return true;}// ...省略其他方法
}

 

ArrayList的核心是一个数组。当添加元素会超过当前数组大小时,会触发一个“扩容”操作,通常是将数组大小增加到当前大小的1.5倍。

  • LinkedList 源码关键部分
public class LinkedList<E> extends AbstractSequentialList<E> implements List<E>, Deque<E>, Cloneable, java.io.Serializable {transient Node<E> first;transient Node<E> last;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;}}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++;}// ...省略其他方法
}

 

LinkedList中的每个元素都是一个节点对象,包含了数据和两个指向其它节点的引用。

4. 代码演示

以下代码展示了ArrayListLinkedList的基本使用:

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;public class ListExample {public static void main(String[] args) {List<String> arrayList = new ArrayList<>();List<String> linkedList = new LinkedList<>();// 添加元素arrayList.add("Element1");linkedList.add("Element1");// 在列表中间插入元素arrayList.add(0, "Element2"); // O(n)linkedList.add(0, "Element2"); // O(1), 只需要改变引用// 获取元素String elementFromArrayList = arrayList.get(1); // O(1)String elementFromLinkedList = linkedList.get(1); // O(n), 需要从头遍历链表// 删除元素arrayList.remove(0); // O(n)linkedList.remove(0); // O(1), 只需要改变引用}
}

 

5. 细节和使用场景

  • ArrayList

    • 优先选择,当需要频繁访问列表中的元素。
    • 注意处理扩容操作,可能会导致短暂的性能下降。
    • 更低的内存占用。
  • LinkedList

    • 当需要频繁进行添加和删除操作,尤其是在列表的开头或中间时,可以考虑使用。
    • 每个元素占用更多内存,因为存储了两个额外的引用。

理解这些区别和细节可以帮助你做出适合你应用场景的数据结构选择。尽管LinkedList在某些操作中有其优势,但由于内存使用和大多数操作中的性能影响,ArrayList通常是默认首选。只有在特定的、频繁进行插入和删除的场景下,LinkedList才是更好的选择。

 

http://www.ds6.com.cn/news/90147.html

相关文章:

  • wordpress postgresqlseo怎么优化简述
  • 网站开发项目意义百度一下百度知道
  • 农业基本建设项目信息网站推广app是什么工作
  • 洛阳做家教去什么网站专业恶意点击软件
  • 电脑做网站教学怎么写软文推广
  • 如何做图片 网站 链接网络营销名词解释答案
  • 南阳网页制作公司东莞网站seo优化托管
  • 差异基因做聚类分析网站seo是什么意思蜘蛛屯
  • o2o电子商务网站建设138ip查询网域名解析
  • 南通科技网站建设南京百度seo排名
  • 做外贸的要有自己的网站吗郑州网络推广服务
  • 跨境电商网站 建设要求台州网络推广
  • 云南昆明网站建设公司武汉建站优化厂家
  • 企业网站怎么做软文接单平台
  • 复旦学霸张立勇做的有关寺庙网站上海网络公司seo
  • 做cpa色诱网站用什么域名空间建站搜索引擎优化中的步骤包括
  • 资源网站快速优化排名有什么好用的搜索引擎
  • 医疗网站 seo怎么做竞价培训
  • 嘉兴网页制作网站排名百度seo推广价格
  • 河北省建设网站锁安装什么驱动seo和sem哪个工资高
  • 预付网站制作费怎么做凭证长春网站建设公司哪家好
  • 建设平台公司公司seo是指什么意思
  • 网站运营开发托管海外推广渠道
  • 怎么优化推广自己的网站快排seo软件
  • 西宁疫情最新消息今天新增病例北京网优化seo公司
  • 可以做动效的网站必应搜索引擎网址
  • 平价网站平价网站建设建设什么都不懂能去干运营吗
  • 雷州网站开发公司网站如何做seo排名
  • 阻止网站查到访问者ip新郑网络推广
  • 网站开发网站制作报价国外网络推广