【JAVA-Day49】Java LinkedList集合详解

Java LinkedList集合详解

  • 摘要
  • 引言
    • Java LinkedList集合详解
      • 一、什么是LinkedList集合
        • 1.1 链表数据结构
        • 1.2 双向链表
        • 1.3 动态大小
        • 1.4 插入和删除元素
        • 1.5 适用场景
      • 二、LinkedList集合的使用
        • 2.1 创建 LinkedList 集合、添加元素、遍历元素
        • 2.2 在指定位置插入元素
        • 2.3 获取指定位置的元素
        • 2.4 删除指定位置的元素
        • 2.5 在开头或末尾插入元素
      • 三、LinkedList集合的应用场景
        • 3.1 实现队列
        • 3.2 实现栈
        • 3.3 实现双端队列
        • 3.4 处理实时数据流
        • 3.5 实现其他数据结构
      • 四、LinkedList面试题
      • 五、Java LinkedList与ArrayList对比
        • 5.1 Java集合类LinkedList和ArrayList的对比分析
        • 5.2 链表与顺序表:它们在Java中有何不同?
        • 5.3 选择Java LinkedList还是ArrayList:优劣对比
      • 六、性能优化和最佳实践
        • 6.1 Java LinkedList的性能优化技巧
        • 6.2 链表与顺序表的优势与劣势:Java中如何选择?
      • 七、Java LinkedList的内部实现和工作原理
      • 八、高级应用和性能比较
      • 8.1 使用 LinkedList 构建高效数据结构:详细指南
        • 8.1.1 插入和删除操作
        • 8.1.2 迭代器遍历
        • 8.1.3 自定义节点
        • 8.1.4 注意内存占用
        • 8.1.5 避免随机访问
      • 8.2 Java 集合类 LinkedList 和 ArrayList 的性能比较
        • 8.2.1 插入和删除操作
        • 8.2.2 随机访问
        • 8.2.3 空间占用
        • 8.2.4 遍历性能
        • 8.2.5 选择建议
      • 九、LinkedList的使用案例
        • 9.1 场景描述
        • 9.2 使用LinkedList的任务管理器
        • 9.3 案例解释
      • 十、总结

在这里插入图片描述
在这里插入图片描述

博主 默语带您 Go to New World.
个人主页—— 默语 的博客👦🏻
《java 面试题大全》
🍩惟余辈才疏学浅,临摹之作或有不妥之处,还请读者海涵指正。☕🍭
《MYSQL从入门到精通》数据库是开发者必会基础之一~
🪁 吾期望此文有资助于尔,即使粗浅难及深广,亦备添少许微薄之助。苟未尽善尽美,敬请批评指正,以资改进。!💻⌨


在这里插入图片描述

摘要

欢迎来到我的技术博客,本篇文章将深入探讨Java中的LinkedList集合。我们将首先介绍LinkedList的基本概念和结构,然后逐一讨论其用法、应用场景以及性能比较。通过本文,您将全面了解Java中LinkedList的内部实现和工作原理,以及如何优化其性能。最后,我们将回顾所学内容并提供实际应用案例,帮助您成为Java LinkedList的高级用户。

引言

在Java编程中,数据结构的选择对于程序性能和效率至关重要。其中,LinkedList是一种常见的数据结构,但与ArrayList等其他集合类相比,它有着独特的特点。本文将带您深入了解Java LinkedList,探讨其内部实现、使用方式以及性能方面的考虑,以便您在实际项目中作出明智的选择。

Java LinkedList集合详解

一、什么是LinkedList集合

LinkedList是一种双向链表实现的集合,它以节点相互连接的方式存储数据,具有动态大小和高度灵活的特性。这使得LinkedList适合在特定场景下使用,尤其在插入和删除元素频繁的情况下。


LinkedList是一种双向链表实现的集合,它以节点相互连接的方式存储数据,具有动态大小和高度灵活的特性。这使得LinkedList适合在特定场景下使用,尤其在插入和删除元素频繁的情况下。在这一部分,我们将更深入地探讨LinkedList的结构和工作原理。

1.1 链表数据结构

LinkedList基于链表数据结构,每个元素(节点)都包含数据和指向前一个节点和后一个节点的引用。这种结构使得在链表中插入和删除元素的开销相对较低,因为只需要调整相邻节点的引用,而不必像数组那样移动大量元素。

1.2 双向链表

LinkedList是双向链表,这意味着每个节点都有一个指向前一个节点和一个指向后一个节点的引用。这使得在双向链表中可以双向遍历,从而更容易实现某些操作。

1.3 动态大小

与数组不同,LinkedList的大小可以动态增长或缩小。当需要添加或移除元素时,它可以根据需要自动调整大小,而无需预先分配固定大小的内存。

1.4 插入和删除元素

由于LinkedList的特性,它在插入和删除元素方面非常高效。当插入元素时,只需更改相邻节点的引用,而不需要移动整个集合。同样,删除元素也只需要更新相邻节点的引用,而不必移动其他元素。

1.5 适用场景

LinkedList在以下情况下特别适用:

  • 需要频繁插入和删除元素,而不关心随机访问。
  • 需要实现队列、栈或双端队列等数据结构。
  • 处理实时数据流,其中数据的插入和删除频率较高。

LinkedList的这些特性使它在特定应用中非常有价值。在接下来的部分中,我们将深入研究如何使用LinkedList以及在何种情境下选择它。

二、LinkedList集合的使用

2.1 创建 LinkedList 集合、添加元素、遍历元素

首先,让我们演示如何创建一个LinkedList集合、向其中添加元素,并遍历集合中的元素:

LinkedList<String> linkedList = new LinkedList<>();
linkedList.add("Java");
linkedList.add("is");
linkedList.add("awesome");for (String element : linkedList) {System.out.println(element);
}

这段代码展示了如何创建一个LinkedList集合,并使用add方法将字符串元素添加到集合中。随后,我们使用增强for循环遍历集合中的元素并将它们打印出来。

2.2 在指定位置插入元素

如果您需要在特定位置插入元素,可以使用add(index, element)方法。下面是一个示例:

linkedList.add(1, "programming");

这将在LinkedList的索引1处插入字符串"programming"。这是LinkedList的一个有用功能,尤其在需要在特定位置插入元素时非常实用。

2.3 获取指定位置的元素

如果您需要获取特定位置的元素,可以使用get(index)方法。以下是一个示例:

String secondElement = linkedList.get(1);

这将获取LinkedList中索引1处的元素,并将其存储在secondElement变量中。

2.4 删除指定位置的元素

要删除特定位置的元素,可以使用remove(index)方法。例如:

linkedList.remove(2); // 删除第三个元素

这会从LinkedList中删除索引2处的元素,实现了高效的元素删除操作。

2.5 在开头或末尾插入元素

如果您需要在LinkedList的开头或末尾插入元素,可以使用addFirst(element)addLast(element)方法。这是一种高效的方式,例如:

linkedList.addFirst("Hello");
linkedList.addLast("World");

这些方法允许您轻松地在LinkedList的开头或末尾添加新元素,而不必进行复杂的元素移动操作。

通过这些示例,您可以更好地了解如何使用LinkedList集合的各种功能,包括添加、遍历、插入和删除元素。 LinkedList的灵活性和性能使其在特定场景下成为一种强大的数据结构选择。接下来,我们将继续探讨LinkedList的应用场景和性能比较。

三、LinkedList集合的应用场景

LinkedList在实际编程中有多种应用场景,包括实现队列、栈、双端队列等数据结构。由于其高效的插入和删除操作,它在特定情境下非常有用,例如处理实时数据流。


3.1 实现队列

队列是一种数据结构,遵循"先进先出"(FIFO)的原则。LinkedList可以用作队列的底层数据结构,因为它允许高效地在队列的末尾添加元素(入队)和在队列的开头移除元素(出队)。这使得LinkedList成为实现队列的一种优秀选择。

3.2 实现栈

栈是一种数据结构,遵循"后进先出"(LIFO)的原则。LinkedList同样可以用作栈的底层数据结构。在栈中,元素的插入和删除操作都发生在同一端(栈顶),而LinkedList能够高效地执行这些操作,使其成为实现栈的良好选择。

3.3 实现双端队列

双端队列(Deque,即"double-ended queue")是一种数据结构,允许在队列的两端进行插入和删除操作。LinkedList提供了在双端队列中高效执行这些操作的能力,使其成为实现双端队列的有力工具。

3.4 处理实时数据流

在实时数据流处理中,数据的插入和删除频率非常高,因此需要一种能够高效处理这种情况的数据结构。LinkedList的能力在此方面非常突出,因为它可以在特定位置高效地插入和删除元素,而不会导致过多的性能开销。

3.5 实现其他数据结构

除了上述应用场景,LinkedList还可以用于实现其他数据结构,如优先队列、链接表等。其灵活性和高效的插入和删除操作使其适用于各种数据结构的构建。

总之,LinkedList在实际编程中有多种应用场景,尤其适用于需要高效地进行元素插入和删除操作的情况。通过了解这些应用场景,您可以更好地选择适当的数据结构来解决特定的编程问题。在接下来的部分,我们将探讨LinkedList的性能比较以及如何优化其性能。

四、LinkedList面试题

挑战自己的LinkedList知识,检验您是否已经掌握了LinkedList的关键概念和用法。以下是一个问题示例:

问题: LinkedList和ArrayList有什么区别,何时选择使用它们?

LinkedList和ArrayList的区别:

  1. 数据结构:LinkedList基于双向链表实现,而ArrayList基于动态数组实现。这是它们最显著的区别。
  2. 随机访问:ArrayList支持常数时间(O(1))的随机访问,因为它可以通过索引迅速访问元素。相比之下,LinkedList的随机访问时间较长(O(n)),因为需要从头或尾部开始遍历链表以达到目标位置。
  3. 插入和删除:LinkedList在插入和删除元素方面更加高效,因为它只需要调整相邻节点的引用。ArrayList在中间插入或删除元素时需要移动其他元素,因此性能可能较差。
  4. 内存占用:LinkedList通常需要更多的内存空间来存储额外的指针。相比之下,ArrayList通常具有更低的内存占用。

何时选择使用它们:

  • 使用ArrayList
    • 当需要频繁随机访问元素或迭代集合中的元素时,ArrayList通常更为合适,因为它的性能更好。
    • 当内存使用需求较低或不涉及大规模插入和删除操作时,ArrayList也是一个不错的选择。
  • 使用LinkedList
    • 当需要频繁插入和删除元素,而不关心随机访问时,LinkedList可能更合适,因为它在这些操作上性能更出色。
    • 当实现队列、栈、双端队列等数据结构时,LinkedList通常是更好的选择,因为它的插入和删除操作非常高效。
    • 在处理实时数据流或需要在中间插入/删除元素的情况下,LinkedList可能更适合,因为它不需要元素的移动操作。

总之,选择ArrayList还是LinkedList取决于您的具体需求。了解它们的区别以及在何时使用它们可以帮助您做出明智的数据结构选择。这也反映了在编程中选择合适的数据结构是一项重要的决策,需要根据特定情况来权衡性能和功能。

五、Java LinkedList与ArrayList对比

5.1 Java集合类LinkedList和ArrayList的对比分析

LinkedListArrayList是Java中两种不同类型的集合,它们在数据结构和性能方面存在显著差异。

  • 数据结构:LinkedList是基于双向链表实现的,每个元素都包含指向前一个和后一个元素的引用。ArrayList基于动态数组实现,它在内存中分配一块连续的空间来存储元素。
  • 随机访问:ArrayList支持常数时间(O(1))的随机访问,因为可以通过索引直接访问元素。LinkedList的随机访问时间相对较长(O(n)),因为需要从头部或尾部开始遍历链表以达到目标位置。
  • 插入和删除:LinkedList在插入和删除元素方面更高效,因为只需要调整相邻节点的引用。ArrayList在中间插入或删除元素时需要移动其他元素,因此性能可能较差。
  • 内存占用:LinkedList通常需要更多的内存空间来存储额外的指针,而ArrayList通常具有较低的内存占用。
5.2 链表与顺序表:它们在Java中有何不同?
  • 链表(LinkedList):链表是一种线性数据结构,由节点组成,每个节点包含数据和指向下一个节点的引用。链表支持高效的插入和删除操作,特别适用于需要频繁插入和删除元素的场景。链表的缺点是随机访问性能较差,需要按顺序遍历查找元素。
  • 顺序表(ArrayList):顺序表是一种线性数据结构,由数组实现。它支持高效的随机访问,因为可以通过索引直接访问元素。但在插入和删除操作中,如果需要移动元素,性能可能较差。
5.3 选择Java LinkedList还是ArrayList:优劣对比

何时选择使用Java LinkedList

  • 当需要频繁插入和删除元素,而不关心随机访问性能时,LinkedList通常更合适。
  • 当实现队列、栈、双端队列等数据结构时,LinkedList通常是更好的选择,因为它的插入和删除操作非常高效。
  • 在处理实时数据流或需要在中间插入/删除元素的情况下,LinkedList可能更适合,因为它不需要元素的移动操作。

何时选择使用Java ArrayList

  • 当需要频繁随机访问元素或迭代集合中的元素时,ArrayList通常更为合适,因为它的性能更好。
  • 当内存使用需求较低或不涉及大规模插入和删除操作时,ArrayList也是一个不错的选择。

在选择LinkedList还是ArrayList时,需要根据具体需求和性能考虑做出决策。了解它们的区别和优劣势可以帮助您在项目中选择适当的数据结构,以满足特定的编程需求

六、性能优化和最佳实践

6.1 Java LinkedList的性能优化技巧

优化Java中的LinkedList性能是重要的,特别是在处理大型数据集时。以下是一些性能优化技巧:

  • 避免频繁使用get(index):如前所述,LinkedList的随机访问效率较低。如果需要频繁访问元素,考虑将元素缓存在局部变量中,以减少不必要的get操作。
  • 使用Iterator进行遍历:使用Iterator而不是增强for循环进行遍历,因为Iterator可以更好地处理链表的结构。遍历时使用listIterator()方法可以在双向链表中进行双向遍历。
  • 注意内存开销:LinkedList需要额外的内存来存储指向前后节点的引用,因此在处理大型数据集时要注意内存开销。确保你有足够的内存来处理数据。
  • 考虑分批操作:如果需要批量插入或删除元素,可以考虑将操作分成多个小批次,以减少元素移动的次数。
  • 使用addFirstaddLast:如果需要在链表的开头或末尾插入元素,使用addFirstaddLast方法,因为它们效率更高。
6.2 链表与顺序表的优势与劣势:Java中如何选择?

链表和顺序表在Java中都有各自的优势和不足。以下是一些考虑因素:

  • 使用链表的情况
    • 当需要频繁插入和删除元素,而不关心随机访问时,链表通常更合适。
    • 在实现队列、栈、双端队列等数据结构时,链表通常是更好的选择,因为它的插入和删除操作非常高效。
    • 在处理实时数据流或需要在中间插入/删除元素的情况下,链表可能更适合,因为它不需要元素的移动操作。
  • 使用顺序表的情况
    • 当需要频繁随机访问元素或迭代集合中的元素时,顺序表(如ArrayList)通常更为合适,因为它的性能更好。
    • 当内存使用需求较低或不涉及大规模插入和删除操作时,顺序表也是一个不错的选择。

在选择链表还是顺序表时,需要根据具体需求和性能考虑做出决策。了解它们的相对优势和不足可以帮助您在Java项目中做出明智的选择,以满足特定的编程需求。同时,性能优化技巧和最佳实践对于确保链表在实际项目中表现出色也非常重要。

七、Java LinkedList的内部实现和工作原理

深入了解Java LinkedList的内部机制和工作原理,为更高级的使用打下基础。


  • 双向链表结构:LinkedList由节点组成,每个节点包含数据和指向前一个节点(前驱)和后一个节点(后继)的引用。这种双向链表结构允许在链表中双向遍历。
  • 头节点和尾节点:LinkedList的头节点是链表的第一个节点,尾节点是链表的最后一个节点。它们分别存储在头部和尾部,允许高效地在链表的开头和末尾执行插入和删除操作。
  • 添加元素:当您向LinkedList添加元素时,它会创建一个新的节点,将数据存储在其中,并将前一个节点和后一个节点的引用正确连接起来,以维护链表的完整性。这使得在链表的开头或末尾添加元素非常高效。
  • 删除元素:删除元素时,LinkedList会调整前一个节点和后一个节点的引用,从而将目标节点从链表中移除。这也是链表在删除操作上高效的原因。
  • 迭代器(Iterator):LinkedList提供了迭代器,用于遍历链表的元素。迭代器允许您在链表中移动并访问各个节点,执行迭代操作。
  • 内部实现细节:Java中的LinkedList是基于Node类实现的,每个Node对象都包含数据和指向前一个节点和后一个节点的引用。链表的头部和尾部分别由特殊的headertail节点表示。

深入了解LinkedList的内部实现和工作原理对于理解其性能和用法非常重要。这种数据结构在特定场景下非常有用,了解它的内部工作方式有助于更好地利用它的特性。在项目中使用LinkedList时,您可以利用这些知识来更好地处理数据和性能需求。

八、高级应用和性能比较

8.1 使用 LinkedList 构建高效数据结构:详细指南

LinkedList 是 Java 中的一个双向链表实现,相较于 ArrayList,它在插入和删除元素时更为高效。在构建高效数据结构时,可以利用 LinkedList 的特性来满足特定需求。以下是一些详细指南:

8.1.1 插入和删除操作

由于 LinkedList 是一个链表,插入和删除操作的时间复杂度为 O(1),这使得它非常适合需要频繁插入和删除操作的场景。在构建高效数据结构时,考虑如何充分利用这一特性,设计数据结构以最大程度地减少元素的移动和复制。

8.1.2 迭代器遍历

LinkedList 提供了迭代器(Iterator)接口,可以通过迭代器高效地遍历元素。在构建高效数据结构时,考虑如何设计迭代器以提高遍历性能。

8.1.3 自定义节点

LinkedList 的节点是双向的,保存了前一个节点和后一个节点的引用。在构建高效数据结构时,可以考虑自定义节点结构,以满足特定的需求。例如,可以添加额外的信息或引用,以提高某些操作的效率。

8.1.4 注意内存占用

虽然 LinkedList 在插入和删除操作上有优势,但它在内存占用上可能较大。在构建高效数据结构时,需要权衡空间复杂度和时间复杂度,确保选择的数据结构符合实际需求。

8.1.5 避免随机访问

LinkedList 的随机访问效率较低,因为要从头或尾开始遍历。在构建高效数据结构时,如果需要频繁进行随机访问,可能需要考虑其他数据结构,比如 ArrayList。

8.2 Java 集合类 LinkedList 和 ArrayList 的性能比较

在选择数据结构时,了解其性能特点是至关重要的。下面是 Java 中 LinkedList 和 ArrayList 的性能比较:

8.2.1 插入和删除操作
  • LinkedList: 插入和删除操作的时间复杂度为 O(1)。在链表中,只需要修改相邻节点的引用即可完成插入和删除。
  • ArrayList: 在插入和删除操作中,涉及到元素的移动,因此时间复杂度为 O(n)。特别是在列表的中间或开头插入/删除元素时,性能相对较差。
8.2.2 随机访问
  • LinkedList: 随机访问的时间复杂度为 O(n),因为必须从头或尾开始遍历链表。
  • ArrayList: 随机访问的时间复杂度为 O(1),因为底层是数组结构,可以通过索引直接访问元素。
8.2.3 空间占用
  • LinkedList: 链表结构需要额外的空间存储节点的引用,可能导致较大的内存占用。
  • ArrayList: 数组结构在存储元素时更加紧凑,通常情况下占用的内存较少。
8.2.4 遍历性能
  • LinkedList: 在迭代(遍历)操作时,由于有指向前后节点的引用,LinkedList 的性能较好。
  • ArrayList: 在迭代操作时,由于底层是数组,ArrayList 的性能也是相当不错的。
8.2.5 选择建议
  • 使用 LinkedList 当:
    • 需要频繁进行插入和删除操作。
    • 对随机访问的性能要求不高。
    • 可以接受较大的内存占用。
  • 使用 ArrayList 当:
    • 需要频繁进行随机访问操作。
    • 对插入和删除的性能要求不是很高。
    • 有限制的内存资源。

在实际项目中,根据具体的使用场景和操作需求,选择合适的集合类是至关重要的。

import java.util.LinkedList;
import java.util.List;
import java.util.ListIterator;public class EfficientDataStructure {// Demo for Efficient Data Structure using LinkedListpublic static void main(String[] args) {// Creating a custom data structure using LinkedListEfficientLinkedListStructure<String> customList = new EfficientLinkedListStructure<>();// Adding elements to the custom data structurecustomList.add("Element 1");customList.add("Element 2");customList.add("Element 3");// Displaying the elementsSystem.out.println("Custom List Elements: " + customList);// Demonstrating efficient traversal using custom iteratorSystem.out.print("Custom Iterator Traversal: ");ListIterator<String> customIterator = customList.customIterator();while (customIterator.hasNext()) {System.out.print(customIterator.next() + " ");}}}// Custom data structure using LinkedList
class EfficientLinkedListStructure<E> {private LinkedList<E> linkedList;// Constructor to initialize the LinkedListpublic EfficientLinkedListStructure() {this.linkedList = new LinkedList<>();}// Custom method for adding elements with optimized insertionpublic void add(E element) {linkedList.addLast(element);}// Custom iterator for efficient traversalpublic ListIterator<E> customIterator() {return linkedList.listIterator();}// Overriding toString for a readable display of elements@Overridepublic String toString() {return linkedList.toString();}}

九、LinkedList的使用案例

在Java开发中,LinkedList的灵活性使其在各种场景中都能发挥重要作用。以下是一个简单的使用案例,演示了如何在实际项目中利用LinkedList解决问题。

9.1 场景描述

假设我们需要实现一个任务管理器,其中包含一组任务,并能够在任务之间进行快速的插入和删除操作。由于任务管理经常涉及到插入和删除,因此选择使用LinkedList来提高操作效率。

9.2 使用LinkedList的任务管理器
import java.util.LinkedList;class Task {String description;public Task(String description) {this.description = description;}@Overridepublic String toString() {return "Task: " + description;}
}public class TaskManager {private LinkedList<Task> taskList = new LinkedList<>();// 添加任务public void addTask(String description) {Task newTask = new Task(description);taskList.addLast(newTask);System.out.println("Task added: " + newTask);}// 移除任务public void removeTask(int index) {if (index >= 0 && index < taskList.size()) {Task removedTask = taskList.remove(index);System.out.println("Task removed: " + removedTask);} else {System.out.println("Invalid index for task removal.");}}// 显示所有任务public void displayTasks() {System.out.println("Tasks in the Task Manager:");for (Task task : taskList) {System.out.println(task);}}public static void main(String[] args) {TaskManager taskManager = new TaskManager();// 添加任务taskManager.addTask("Complete Java tutorial");taskManager.addTask("Finish project proposal");// 显示所有任务taskManager.displayTasks();// 移除任务taskManager.removeTask(1);// 显示更新后的任务列表taskManager.displayTasks();}
}
9.3 案例解释
  • Task 类表示任务,具有描述信息。
  • TaskManager 类使用LinkedList来存储任务列表,并提供了添加、移除和显示任务的方法。
  • main方法中,演示了如何创建任务、显示所有任务、移除任务,并展示了LinkedList在这个任务管理场景中的灵活性。

十、总结

在本文中,我们深入研究了LinkedList的基本概念、高级应用和性能比较,并通过实际案例展示了如何在Java开发中充分利用LinkedList。LinkedList适用于需要频繁插入和删除操作的场景,特别是在任务管理、编辑器撤销操作等方面。在选择数据结构时,根据具体需求和场景特点,LinkedList可以成为Java开发者的强大工具之一。

在这里插入图片描述


🪁🍁 希望本文能够给您带来一定的帮助🌸文章粗浅,敬请批评指正!🍁🐥

如对本文内容有任何疑问、建议或意见,请联系作者,作者将尽力回复并改进📓;(联系微信:Solitudemind )

点击下方名片,加入IT技术核心学习团队。一起探索科技的未来,共同成长。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/167176.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

聊聊分布式架构10——Zookeeper入门详解

目录 01ZooKeeper的ZAB协议 ZAB协议概念 ZAB协议基本模式 消息广播 崩溃恢复 选举出新的Leader服务器 数据同步 02Zookeeper的核心 ZooKeeper 的核心特点 ZooKeeper 的核心组件 选举算法概述 服务器启动时的Leader选举 服务器运行期间的Leader选举 03ZooKeeper的…

【vue+nestjs】qq第三方授权登录【超详细】

项目场景&#xff1a; 前端使用vue3ts 后端使用nestjs 1.申请appId,appKey 1.进入qq互联官网。创建应用 特别注意 1.在填写网站回调域时,需要你线上真实能访问的。不然审核不通过。我的回调地址是前端路由地址 2.如果你想本地调试&#xff0c;回调到你的线上地址。你可以在本…

面试算法31:最近最少使用缓存

题目 请设计实现一个最近最少使用&#xff08;Least Recently Used&#xff0c;LRU&#xff09;缓存&#xff0c;要求如下两个操作的时间复杂度都是O&#xff08;1&#xff09;。 get&#xff08;key&#xff09;&#xff1a;如果缓存中存在键key&#xff0c;则返回它对应的值…

基于Django与深度学习的股票预测系统 计算机竞赛

文章目录 0 前言1 课题背景2 实现效果3 Django框架4 数据整理5 模型准备和训练6 最后 0 前言 &#x1f525; 优质竞赛项目系列&#xff0c;今天要分享的是 &#x1f6a9; **基于Django与深度学习的股票预测系统 ** 该项目较为新颖&#xff0c;适合作为竞赛课题方向&#xff…

Redis基本命令和常用数据类型

文章目录 前言一、Redis简介二、基本操作1.赋值2.取值3.切换数据库4.查看数据库所有键&#xff08;key&#xff09;5.查看键值类型6.移动键值到其他数据库7.设置键值生存时间&#xff08;两种&#xff09;8.查看键值生存时间9.查看当前数据库大小10.判断键是否存在11.清空当前数…

基于ResNet34的花朵分类

一.数据集准备 新建一个项目文件夹ResNet&#xff0c;并在里面建立data_set文件夹用来保存数据集&#xff0c;在data_set文件夹下创建新文件夹"flower_data"&#xff0c;点击链接下载花分类数据集https://storage.googleapis.com/download.tensorflow.org/example_i…

英语什么时候加s和es

名词变复数一般情况下加s&#xff0c;以s,x,ch,sh结尾加es。一个名词如果表示一个或一样东西&#xff0c;它取单数形式&#xff0c;如果表示两个或更多的这类东西&#xff0c;则需要用名词复数形式。 1 以s,x,sh,ch结尾的词&#xff0c;加es。 2 以辅音字母&#xff08;除a/e/…

钢铁异常分类 few-shot 问题 小陈读paper 钢铁2

很清爽的 abstract 给出链接 前面的背景意义 其实 是通用的 这里替大家 整理一吓吓 1 缺陷分类在钢铁表面缺陷检测中 有 意义。 2 大多数缺陷分类模型都是基于完全监督的学习&#xff0c; 这需要大量带有图像标签的训练数据。 在工业场景中收集有缺陷的图像是非常困难…

C++11——lambda表达式

文章目录 1. C98对自定义类型的排序2. lambda表达式语法2.1 捕捉列表 3. lambda底层原理 1. C98对自定义类型的排序 在C98中&#xff0c;想要对自定义类型就行排序&#xff0c;我们得自己写仿函数来表明我们相对哪一项进行排序 struct Student {Student(string name, long id…

计算机算法分析与设计(16)---Dijkstra算法(含C++代码)

文章目录 一、知识概述1.1 算法描述1.2 例题分析 二、代码编写 一、知识概述 1.1 算法描述 1.2 例题分析 二、代码编写 输入&#xff1a;  第一行&#xff1a;图的顶点数n  第二行&#xff1a;图的边数k  第三行&#xff1a;算法起点begin&#xff0c;算法终点end  接下来…

物联网AI MicroPython传感器学习 之 RTC时钟模块

学物联网&#xff0c;来万物简单IoT物联网&#xff01;&#xff01; 一、产品简介 DS1302 是DALLAS 公司推出的涓流充电时钟芯片&#xff0c;内含有一个实时时钟/日历和31字节静态RAM&#xff0c;实时时钟/日历电路提供秒、分、时、日、周、月、年的信息&#xff0c;每月的天数…

Tomcat启动控制台乱码问题

修改Tomcat/conf/logging.properties

微信小程序中如何使用fontawesome6的免费图标

一、官网下载fontawesome6 Download Font Awesome Free or Pro | Font Awesome 二、使用transfer编码成Base64 transfer打开官网&#xff1a;Online font-face generator — Transfonter 首先先把刚刚下载的fontawesome6解压&#xff0c;将文件夹中的字体上传&#xff08;点…

【MATLAB第80期】基于MATLAB的结构核岭回归SKRR多输入单输出回归预测及分类预测模型

【MATLAB第80期】基于MATLAB的结构核岭回归SKRR多输入单输出回归预测及分类预测模型 SKRR这是Gustau Camps-Valls等人在“用深度结构核回归检索物理参数”中提出的结构核岭回归&#xff08;SKRR&#xff09;方法。 参考文献&#xff1a; Camps-Valls,Retrieval of Physical Pa…

[C++] C++入门

☃️个人主页&#xff1a;fighting小泽 &#x1f338;作者简介&#xff1a;目前正在学习C和Linux &#x1f33c;博客专栏&#xff1a;C入门 &#x1f3f5;️欢迎关注&#xff1a;评论&#x1f44a;&#x1f3fb;点赞&#x1f44d;&#x1f3fb;留言&#x1f4aa;&#x1f3fb; …

JUC并发编程笔记2

省流&#xff1a; 自己笔记&#xff0c;划走~~~~ 缓存更新策略

【数据科学赛】2023全球智能汽车AI挑战赛 #¥95000 #LLM文档问答 #视频理解

CompHub[1] 最新的比赛会第一时间在群里通知&#xff0c;欢迎加群交流比赛经验&#xff01;&#xff08;公众号回复“加群”即可&#xff09; 以下内容由AI辅助生成&#xff0c;可能存在错误&#xff0c;可进入比赛主页[2]查看更多(文末阅读原文) 比赛主办方 吉利汽车集团、阿…

2008-2021年上市公司实体企业金融化程度测算数据(原始数据+stata代码)

2008-2021年上市公司实体企业金融化程度测算&#xff08;原始数据stata代码&#xff09; 1、时间&#xff1a;2008-2021年 2、指标&#xff1a;股票代码、年份、交易性金融资产、衍生金融资产、发放贷款及垫款净额、可供出售金融资产净额、持有至到期投资净额、长期债权投资净…

Golang数组:全面指南与实际示例

揭示Golang数组的威力&#xff1a;从基础到高级技巧 Golang数组是数据存储的基本构建块&#xff0c;为开发人员提供了多种可能性。在这篇正式的博客文章中&#xff0c;我们将探讨Golang数组&#xff0c;从基础知识到高级技巧。通过实际示例和正式的语气&#xff0c;我们将揭示…

react 学习 —— 16、使用 ref 操作 DOM

什么时候使用 ref 操作 DOM&#xff1f; 有时你可能需要访问由 React 管理的 DOM 元素 —— 例如&#xff0c;让一个节点获得焦点、滚动到它或测量它的尺寸和位置。在 React 中没有内置的方法来做这些事情&#xff0c;所以你需要一个指向 DOM 节点的 ref 来实现。 怎么使用 r…