【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.mzph.cn/news/114645.shtml

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

相关文章

Maven的详细介绍(maven的全据配置以及idea中maven的配置)

maven的理解 Maven 是一个强大的项目管理和构建自动化工具&#xff0c;它通过抽象的项目对象模型(POM&#xff1a;Project Object Model)和构建生命周期模型(Project Lifecycle)来对项目及其构建过程进行管理(Dependency Management System)&#xff0c;Maven 最大化的消除了构…

【TensorFlow1.X】系列学习笔记【入门二】

【TensorFlow1.X】系列学习笔记【入门二】 大量经典论文的算法均采用 TF 1.x 实现, 为了阅读方便, 同时加深对实现细节的理解, 需要 TF 1.x 的知识 文章目录 【TensorFlow1.X】系列学习笔记【入门二】前言神经网络的参数神经网络的搭建前向传播反向传播 总结 前言 学习了张量、…

SpringBoot 第一个接口编写

RestController //表示该类为请求处理类public class HttpDeal {RequestMapping("/login")//这个方法处理哪一个地址过来的请求public String hello(){return "返回给浏览器";}}

测试Android webview 加载本地html

最近开发一个需要未联网功能的App, 不熟悉使用Java原生开发界面&#xff0c;于是想使用本地H5做界面&#xff0c;本文测试了使用本地html加载远程数据。直接上代码&#xff1a; MainActivity.java package com.alex.webviewlocal;import androidx.appcompat.app.AppCompatAct…

DataGridView的下拉DataGridViewComboBoxColumn的数据绑定问题

DataGridView的下拉DataGridViewComboBoxColumn的数据绑定问题 需求&#xff1a;左边这列固定x行&#xff0c;右边显示下拉&#xff0c;并且赋上默认值 public void Set(){// 添加需要固定显示的行数dataGridView1.Rows.Add("早班";dataGridView1.Rows.Add("中…

小团队之间有哪些好用免费的多人协同办公软件

在小团队协作中&#xff0c;选择适合的多人协同办公软件是提高工作效率和团队协作的重要一环。幸运的是&#xff0c;市场上有许多大多数功能都免费的多人协同办公软件&#xff0c;为小团队提供了强大的协作功能和便捷的工作环境。 在本文中&#xff0c;我将根据自己多年的在线…

[C++] C++入门

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

Cesium Vue(六)— 材质(Material)

1. 设置entity材质 添加棋盘纹理材质 // 棋盘纹理 let material new Cesium.CheckerboardMaterialProperty({ evenColor: Cesium.Color.RED, oddColor: Cesium.Color.YELLOW, repeat: new Cesium.Cartesian2(2, 2), });添加条纹纹理材质 // 条纹纹理 let material new Cesium…

Java利用反射和读取xml实现迷你容器

由于需要框架能实现多态&#xff0c;达到控制反转解耦。所以容器还是需要的&#xff0c;容器的存在可以简化对象获取工作&#xff0c;但是容器也不是万能的。合理使用即可&#xff0c;Spring对我来说太庞大了&#xff0c;用不着&#xff0c;为此给框架写一个迷你版容器。 容器…

Qt中Json的操作

在 Json的两种格式中介绍了Json的格式以及应用场景。由于这种数据格式与语言无关,下面介绍一下Json在Qt中的使用。 从Qt 5.0开始提供了对Json的支持,我们可以直接使用Qt提供的Json类进行数据的组织和解析。相关的类常用的主要有四个,具体如下: Json类介绍 QJsonDocument |…

【vSphere 8 自签名证书】企业 CA 签名证书替换 vSphere Machine SSL 证书Ⅰ—— 生成 CSR

目录 替换拓扑图证书关系示意图说明 & 关联博文 1. 默认证书截图2. 使用certificate-manager生成CSR2.1 创建存放CSR的目录2.2 记录PNID和IP2.3 生成CSR2.4 验证CSR 参考资料 替换拓扑图 证书关系示意图 默认情况下&#xff0c;VMCA 与 Machine SSL的关系是 本系列博文要…

UE5--物体卡片与材质入门

参考资料&#xff1a; 《Unreal Engine5 入门到精通》--左央 虚幻引擎5.2文档&#xff1a;https://docs.unrealengine.com/5.2/zh-CN/ 前言&#xff1a; 跟着左央老师的《Unreal Engine5 入门到精通》学习制作AI版胡闹厨房&#xff0c;把学习过程与学习到的东西归纳总结起来。 …

【网络协议】聊聊网关 NAT机制

再宿舍的时候&#xff0c;其实只能通过局域网进行处理&#xff0c;但是如果接入互联网&#xff0c;一般是配置路由器当然还有网关。 MAC头和IP头的细节 一旦配置了IP地址和网关&#xff0c;就可以制定目标地址进行访问。 MAC头主要信息目标和源MAC地址&#xff0c;以及协议类…

【试题040】多个逻辑或例题2

1.题目&#xff1a;设int n0;&#xff0c;执行表达式n ||(n-1) ||(n0)||(n1)||(n2)后n的值是 &#xff1f; 2.代码解析&#xff1a; 逻辑或 || 运算符是一个短路运算符&#xff0c;它从左到右依次计算表达式&#xff0c;如果遇到一个为真&#xff08;非零&#xff09;的值&am…

uCOSIII实时操作系统 十 事件标志组

目录 事件标志组&#xff1a; 事件标志组API函数&#xff1a; 创建事件标志组&#xff1a; 等待事件标志组&#xff1a; 向事件标志组发送标志&#xff1a; 事件标志组实验&#xff1a; 事件标志组&#xff1a; 有时候一个任务可能需要和多个事件同步这个时候就需要使用事…

39.克鲁斯卡尔(Kruskal)算法

一言 已知n个顶点&#xff0c;选n-1条最短的边&#xff0c;不可成环。 概述 克鲁斯卡尔&#xff08;Kruskal&#xff09;算法是用来求加权连通图的最小生成树的算法。其基本思想是按照权值从小到大的顺序选择n-1条边&#xff0c;保证这n-1条边不构成回路。 这就要求要首先构…

一百九十一、Flume——Flume配置文件各参数含义(持续完善中)

一、目的 在实际项目的开发过程中&#xff0c;不同Kafka主题的数据规模、数据频率&#xff0c;需要配置不同的Flume参数&#xff0c;而这一切的调试、配置工作&#xff0c;都要建立在对Flume配置文件各参数含义的基础上 二、Flume各参数及其含义 &#xff08;一&#xff09;…

集成学习方法(随机森林和AdaBoost)

释义 集成学习很好的避免了单一学习模型带来的过拟合问题 根据个体学习器的生成方式&#xff0c;目前的集成学习方法大致可分为两大类&#xff1a; Bagging(个体学习器间不存在强依赖关系、可同时生成的并行化方法) 流行版本&#xff1a;随机森林(random forest)Boosting(个体…

springboot缓存篇之mybatis一级缓存和二级缓存

前言 相信很多人都用过mybatis&#xff0c;这篇文章主要是介绍mybatis的缓存&#xff0c;了解一下mybatis缓存是如何实现&#xff0c;以及它在实际中的应用 一级缓存 什么是mybatis一级缓存&#xff1f;我们先看一个例子&#xff1a; GetMapping("/list") public…

【Mysql】B+树索引的使用(七)

前言 每个索引都对应一棵 B 树&#xff0c; B 树分为多层&#xff0c;最下边一层是叶子节点&#xff0c;其余的是内节点&#xff08;非叶子节点&#xff09;。所有用户记录都存储在 B 树的叶子节点&#xff0c;所有目录项记录都存储在内节点。 InnoDB 存储引擎会自动为主键&am…