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

做防伪查询网站公司变更股东的流程及所提交的材料

做防伪查询网站,公司变更股东的流程及所提交的材料,旅行社销售网站建设方案,南京市互联网平台公司LinkedList 基本概念 LinkedList 是一个双向链表的实现类,它实现了 List、Deque、Queue 和 Cloneable 接口,底层使用双向链表结构,适合频繁插入和删除操作。 主要特点 有序,可重复。 查询速度较慢,插入/删除速度较…

LinkedList

基本概念

LinkedList 是一个双向链表的实现类,它实现了 ListDequeQueueCloneable 接口,底层使用双向链表结构,适合频繁插入和删除操作。

主要特点

  • 有序,可重复。

  • 查询速度较慢,插入/删除速度较快(相较于 ArrayList)。

  • 允许 null 元素。

  • 线程不安全,效率高于 Vector

常用方法

方法描述
add(E e)在末尾添加元素
add(int index, E element)在指定位置插入元素
remove(int index)删除指定位置元素
get(int index)获取指定位置元素
getFirst() / getLast()获取第一个 / 最后一个元素
removeFirst() / removeLast()删除第一个 / 最后一个元素
offer(E e)添加到队列末尾
poll()弹出队列头部元素

适用场景

  • 频繁增删元素的场景,如队列、栈的实现。

  • 实现双向队列(Deque)。

JAVA中实现队列

// 创建单向链表
LinkedList<String> list = new LinkedList<>();
​
// 添加元素
list.push("元素1");
list.push("元素2");
list.push("元素3");
​
// 遍历链表System.out.println("未移除的链表元素:" + list);
​
//移除元素 最新添加的元素
list.remove();
​
// 遍历链表
System.out.println("移除最新元素后的链表元素:" + list);
​
//创建双向链表
LinkedList<String> queue = new LinkedList<>();
queue.offer("元素A");
queue.offer("元素B");
queue.offer("元素C");
​
// 遍历双向链表
System.out.println("链表元素:" + queue.poll()); // 获取并移除头部元素

Vector

基本概念

Vector 是一种动态数组的实现,线程安全,是 Java 早期的集合类之一。它实现了 List 接口。

主要特点

  • 底层是数组,支持快速随机访问。

  • 增长方式为:容量不足时,扩容为原来的 2 倍

  • 线程安全:所有方法都是同步(synchronized)方法,效率比 ArrayList 低。

  • 允许 null 元素。

常用方法

方法描述
add(E e)添加元素到末尾
add(int index, E element)在指定位置插入
remove(int index)移除指定位置元素
get(int index)获取指定索引元素
size()获取大小
capacity()当前容量
trimToSize()将容量调整为当前大小,节省内存
ensureCapacity(int minCapacity)确保最小容量

适用场景

  • 多线程并发环境中需要使用线程安全的 List。

  • 遗留系统或兼容旧代码(现代开发中很少使用)。

总结对比

Set相关知识

Set 是 Java 集合框架中一个 不允许重复元素 的集合接口。

它的常见实现类包括:

  • HashSet:基于哈希表,无序,查找/插入快。

  • TreeSet:基于红黑树,有序,可排序。

  • LinkedHashSet:有插入顺序,内部基于 HashSet + 双向链表。

HashSet

HashSet 是一个基于 HashMap 实现的 Set,底层使用哈希表来存储元素,不保证元素顺序

public HashSet() {map = new HashMap<>();
}

实际上每个元素都作为 HashMapkey 存储,value 是一个固定对象 PRESENT

添加元素时,先调用 hashCode() → 再调用 equals() 判断是否重复。

时间复杂度:增删查为 O(1)(理想状态下),HashSet 无序的原因是:元素存储在哈希桶中,位置取决于 hashCode

Set<String> set = new HashSet<>();// 添加元素set.add("Hello");set.add("World");set.add("!!");
​//遍历元素for (String s : set) {System.out.println(s);}

TreeSet

TreeSet 是一个有序的 Set,底层基于 红黑树(自平衡二叉搜索树),元素自动按排序顺序排列,不允许重复元素

Set<Integer> treeSet = new HashSet<>();
// 添加元素
treeSet.add(5);
treeSet.add(9);
treeSet.add(3);
treeSet.add(1);
treeSet.add(7);
​
// 遍历元素
treeSet.forEach(System.out::println);
特性HashSetTreeSet
元素是否排序❌ 无序✅ 自动排序
底层结构HashMapTreeMap(红黑树)
插入复杂度O(1)O(log n)
是否允许 null✅ 允许一个⚠️ 最多允许一个(仅在无 Comparator 情况下)
是否线程安全❌ 否❌ 否

特性LinkedListVector
底层结构双向链表动态数组
是否线程安全
插入删除效率
随机访问效率
是否过时是(被 ArrayList + Collections.synchronizedList() 替代)
适用场景队列、栈等多线程旧代码中使用
http://www.dtcms.com/a/468145.html

相关文章:

  • 网站怎么放到服务器上网站建设和网站设计
  • 江门市住房和城乡建设局门户网站wordpress页面id判断
  • 网站建设怎么搭建服务器国家企业信用信息公示官网糸
  • 个人做百度云下载网站吗什么叫电商
  • 可视化网站设计工具网站开发都有什么类别
  • 免费黄页营销网站营销型网站规划建设的七大要素
  • 做健身网站步骤wordpress提问
  • 建设银行嘉兴分行网站首页郑州一建南阳分公司
  • wordpress oracle自学建网站做网站优化
  • 网站建设友汇同安网站建设
  • 长治哪里做网站西安响应式网站建设
  • 根据一个网站仿做新网站是什么网站wordpress透明主题
  • 淘宝天猫优惠券网站建设费用企业手机网站cms系统
  • 用asp做网站上网帮助网址制作二维码
  • 网站建设与运营公司市场开方案asp.net做的网站模板
  • ps做网站原形asp网站后台下载
  • 免费外链网站seo发布山东建设官方网站
  • 强化学习(5)多智能体强化学习
  • 学做网站需要掌握哪些知识网站的橱窗怎么做
  • 怎样在建设厅网站查询安全员证怎么做一个企业的网站
  • 提供免费空间的网站app开发价格多少
  • 宜昌网站建设选择宜昌慧享互动江苏智能网站建设流程
  • 东莞建网站的公app开发及后期维护费用
  • 家乡网站策划书建设背景网站做不了301重定向
  • 杭州网站建设规划网站收录地址
  • 盐城网站建设优化建站惠州网站建设推广
  • 新浪云 建设网站房地产网站建设案例
  • 怎样在网站上做专栏一个公司做网站需要注意什么
  • 怎么查看什么公司做的网站吗用html5做课程教学网站
  • 建设银行网站维护电话网站建设考虑的因素