Java集合框架的全面分析和性能增强

news2024/9/20 8:03:48

Java集合框架的全面分析和性能增强

  • 💗摘要:
  • 💗 1. Java集合框架概述
    • 💗1.1 Collection接口
      • 1.1.1 List接口
      • 1.1.2 Set接口
      • 1.1.3 Queue接口
    • 💗1.2 Map接口
  • 💗2. Java集合框架性能优化
    • 💗2.1 选择合适的集合类型
    • 💗2.2 合理设置容量和负载因子
    • 💗2.3 使用并发集合
    • 💗2.4 注意自定义对象的hashCode()和equals()方法
    • 💗2.5 避免频繁的集合复制
  • 💗结论

💓 💓 💗
🎶 🎶 🎵 🎵

在这里插入图片描述

💗摘要:

Java集合框架在Java编程中起着至关重要的作用。它提供了一系列的数据结构和算法,用于存储、操作和访问数据。然而,为了充分利用集合框架的强大功能,开发人员需要深入了解其内部机制,并注意性能优化。本博客将深度解析Java集合框架的核心组件,包括List、Set、Map等接口及其实现类,同时提供优化技巧和示例,助力新手更好地理解和学习。

💗 1. Java集合框架概述

Java集合框架是Java编程中的基础组件之一,用于存储和操作数据。它提供了一组接口和实现类,支持各种常见的数据结构,如动态数组、链表、哈希表等。Java集合框架主要分为三个层次:

💗1.1 Collection接口

Collection接口是Java集合框架的根接口,定义了一组通用的方法,用于操作集合中的元素。它包括常见的子接口:List、Set、Queue等。

1.1.1 List接口

List接口是有序的集合,允许重复元素。我们最常用的实现类是ArrayListLinkedList。其中,ArrayList基于动态数组实现,适用于随机访问,而LinkedList基于双向链表,适用于频繁插入和删除操作。

// 示例代码:创建ArrayList和LinkedList
List<String> arrayList = new ArrayList<>();
List<Integer> linkedList = new LinkedList<>();

ArrayList是基于动态数组实现的,它允许我们通过索引快速随机访问其中的元素。由于内部使用数组来存储元素,ArrayList在查找操作时具有较快的时间复杂度,通常为O(1)。这使得它非常适合频繁访问和读取元素的场景。此外,它还具有动态扩展和缩减容量的功能,使得其在动态数据集合时表现优异。

另一方面,LinkedList则是基于双向链表实现的。每个元素在LinkedList中都包含一个指向前后元素的引用,这使得在插入和删除操作时具有较快的时间复杂度,通常为O(1)。但是,由于需要遍历链表来查找特定元素,它在随机访问时性能较差,时间复杂度为O(n)。因此,LinkedList在需要频繁的插入和删除操作时表现更为出色。

当我们需要频繁进行元素的随机访问时,ArrayList是更好的选择,因为它具有更高的访问速度。而当我们需要频繁进行元素的插入和删除操作时,LinkedList则更加适合,因为它在这方面表现更出色。根据具体的业务需求,选择合适的List实现类可以帮助我们优化程序性能并提高效率。

// 解析内容:
// List接口是有序的集合,允许重复元素。在Java中,我们最常用的List实现类有ArrayList和LinkedList。
// ArrayList基于动态数组实现,适用于随机访问,而LinkedList基于双向链表,适用于频繁插入和删除操作。

import java.util.ArrayList;
import java.util.LinkedList;
import java.util.List;

public class ListImplementationDemo {

    public static void main(String[] args) {
        // 示例:使用ArrayList和LinkedList实现List接口
        List<String> arrayList = new ArrayList<>(); // 使用ArrayList实现List接口
        List<Integer> linkedList = new LinkedList<>(); // 使用LinkedList实现List接口

        // 向ArrayList和LinkedList中添加元素
        arrayList.add("Apple");
        arrayList.add("Banana");
        arrayList.add("Orange");

        linkedList.add(10);
        linkedList.add(20);
        linkedList.add(30);

        // 遍历ArrayList和LinkedList中的元素
        System.out.println("ArrayList elements:");
        for (String fruit : arrayList) {
            System.out.println(fruit);
        }

        System.out.println("LinkedList elements:");
        for (Integer number : linkedList) {
            System.out.println(number);
        }
    }
}

运行结果

ArrayList elements:
Apple
Banana
Orange

LinkedList elements:
10
20
30


  1. 我们通过import语句导入了ArrayListLinkedList类,它们是Java集合框架中List接口的两个常用实现类。

  2. main方法中,我们创建了一个ArrayList对象和一个LinkedList对象,它们分别实现了List接口,可以存储有序的元素并允许重复。

  3. 通过调用add方法,我们向ArrayListLinkedList中添加元素,分别是字符串和整数。

  4. 使用for-each循环遍历ArrayListLinkedList中的元素,并打印出来。注意,ArrayList的遍历速度相对较快,因为它支持随机访问;而LinkedList的遍历速度较慢,因为它需要按顺序遍历链表。


1.1.2 Set接口

Set接口是无序的集合,不允许重复元素。HashSetTreeSet是常见的实现类,其中HashSet基于哈希表实现,插入和查找速度快,而TreeSet基于红黑树,元素有序且查找速度较快。

// 示例代码:创建HashSet和TreeSet
Set<String> hashSet = new HashSet<>();
Set<Integer> treeSet = new TreeSet<>();

Set接口是Java集合框架中的一种无序集合,它不允许重复元素。在Java中,我们常用的Set实现类有HashSetTreeSet。它们在实现原理和性能上有一些不同。

HashSet: HashSet是基于哈希表实现的Set集合。它使用哈希函数来计算元素的哈希码,然后将元素存储在对应的哈希桶中。HashSet的插入和查找操作非常快,时间复杂度通常为O(1)。这使得它在大多数情况下具有较高的性能优势。但由于HashSet是无序集合,无法保证元素的顺序。

import java.util.HashSet;
import java.util.Set;

public class HashSetDemo {

    public static void main(String[] args) {
        // 示例:使用HashSet实现Set接口
        Set<String> hashSet = new HashSet<>();

        // 添加元素到HashSet
        hashSet.add("Apple");
        hashSet.add("Banana");
        hashSet.add("Orange");

        // 遍历HashSet中的元素
        for (String fruit : hashSet) {
            System.out.println(fruit);
        }
    }
}
Apple
Banana
Orange

TreeSet: TreeSet是基于红黑树实现的Set集合。它会对插入的元素进行排序,因此元素在TreeSet中是有序的。由于使用了红黑树的数据结构,TreeSet在查找操作上比HashSet稍微慢一些,时间复杂度通常为O(log n)。但由于有序性的特点,TreeSet适用于需要有序遍历元素的场景。

import java.util.Set;
import java.util.TreeSet;

public class TreeSetDemo {

    public static void main(String[] args) {
        // 示例:使用TreeSet实现Set接口
        Set<Integer> treeSet = new TreeSet<>();

        // 添加元素到TreeSet
        treeSet.add(10);
        treeSet.add(30);
        treeSet.add(20);

        // 遍历TreeSet中的元素
        for (Integer number : treeSet) {
            System.out.println(number);
        }
    }
}
10
20
30

HashSetTreeSet都是Set接口的实现类,它们分别基于哈希表和红黑树实现。HashSet适用于需要快速插入和查找元素的场景,而TreeSet适用于需要有序遍历元素的场景。根据具体的需求,我们可以选择合适的Set实现类来优化程序性能。

1.1.3 Queue接口

Queue接口是一种特殊的集合,用于实现队列数据结构。常用的实现类有LinkedListPriorityQueue

// 示例代码:创建LinkedList和PriorityQueue
Queue<String> linkedListQueue = new LinkedList<>();
Queue<Integer> priorityQueue = new PriorityQueue<>();

Queue接口是Java集合框架中用于实现队列数据结构的一种特殊集合。队列是一种先进先出(FIFO)的数据结构,元素按照插入的顺序被处理。Queue接口提供了一系列用于操作队列的方法,如添加元素到队尾、移除队头元素、获取队头元素等。

在Java中,我们常用的Queue实现类有LinkedListPriorityQueue

LinkedListLinkedList是基于双向链表实现的Queue。它可以作为普通的队列使用,支持在队尾添加元素(offer()方法)和在队头移除元素(poll()方法)。由于LinkedList实现了Deque接口,还可以用作双端队列,在队头和队尾都可以进行插入和删除操作。


import java.util.LinkedList;
import java.util.Queue;

public class LinkedListQueueDemo {

    public static void main(String[] args) {
        // 示例:使用LinkedList实现Queue接口
        Queue<String> linkedListQueue = new LinkedList<>();

        // 添加元素到队尾
        linkedListQueue.offer("Apple");
        linkedListQueue.offer("Banana");
        linkedListQueue.offer("Orange");

        // 移除队头元素
        String removedElement = linkedListQueue.poll();
        System.out.println("Removed element: " + removedElement);

        // 获取队头元素
        String frontElement = linkedListQueue.peek();
        System.out.println("Front element: " + frontElement);
    }
}

PriorityQueuePriorityQueue是基于优先级堆实现的Queue。它允许我们在插入元素时指定优先级,队头元素始终是优先级最高的元素。默认情况下,PriorityQueue是按照自然顺序或者元素的比较器顺序进行排序的。

import java.util.PriorityQueue;
import java.util.Queue;

public class PriorityQueueDemo {

    public static void main(String[] args) {
        // 示例:使用PriorityQueue实现Queue接口
        Queue<Integer> priorityQueue = new PriorityQueue<>();

        // 添加元素到队列(自动按照优先级排序)
        priorityQueue.offer(10);
        priorityQueue.offer(30);
        priorityQueue.offer(20);

        // 获取并移除队头元素(优先级最高)
        int removedElement = priorityQueue.poll();
        System.out.println("Removed element: " + removedElement);

        // 获取队头元素(优先级最高,但不移除)
        int frontElement = priorityQueue.peek();
        System.out.println("Front element: " + frontElement);
    }
}

Queue接口是实现队列数据结构的一种特殊集合,常用的实现类有LinkedListPriorityQueueLinkedList适用于普通的队列操作,支持在队尾添加和队头移除元素。而PriorityQueue允许我们在插入元素时指定优先级,优先级最高的元素始终位于队头。根据具体的业务需求,我们可以选择合适的Queue实现类来实现队列数据结构。

💗1.2 Map接口

Map接口是一种键值对的映射表,其中键是唯一的,但值可以重复。HashMapTreeMap是常用的实现类,其中HashMap基于哈希表实现,插入和查找速度快,而TreeMap基于红黑树,键有序且查找速度较快。

// 示例代码:创建HashMap和TreeMap
Map<String, Integer> hashMap = new HashMap<>();
Map<String, Integer> treeMap = new TreeMap<>();

Map接口是Java集合框架中用于存储键值对映射的数据结构。在Map中,每个键都是唯一的,但值可以重复。Map接口提供了一系列用于操作键值对的方法,如添加键值对、获取键对应的值、判断键是否存在等。

Java中,我们常用的Map实现类有HashMapTreeMap

HashMapHashMap是基于哈希表实现的Map,它使用哈希函数来计算键的哈希码,然后将键值对存储在对应的哈希桶中。HashMap的插入和查找操作非常快,时间复杂度通常为O(1)。这使得它在大多数情况下具有较高的性能优势。由于哈希表的无序性,HashMap不保证键值对的顺序。


import java.util.HashMap;
import java.util.Map;

public class HashMapDemo {

    public static void main(String[] args) {
        // 示例:使用HashMap实现Map接口
        Map<String, Integer> hashMap = new HashMap<>();

        // 添加键值对到HashMap
        hashMap.put("Apple", 10);
        hashMap.put("Banana", 20);
        hashMap.put("Orange", 30);

        // 获取键对应的值
        int value = hashMap.get("Apple");
        System.out.println("Value for key 'Apple': " + value);
    }
}

TreeMapTreeMap是基于红黑树实现的Map,它会对插入的键进行排序,因此键在TreeMap中是有序的。由于使用了红黑树的数据结构,TreeMap在查找操作上比HashMap稍微慢一些,时间复杂度通常为O(log n)。但由于有序性的特点,TreeMap适用于需要按键的自然顺序或者指定比较器顺序遍历键值对的场景。

import java.util.Map;
import java.util.TreeMap;

public class TreeMapDemo {

    public static void main(String[] args) {
        // 示例:使用TreeMap实现Map接口
        Map<String, Integer> treeMap = new TreeMap<>();

        // 添加键值对到TreeMap
        treeMap.put("Apple", 10);
        treeMap.put("Banana", 20);
        treeMap.put("Orange", 30);

        // 获取键对应的值
        int value = treeMap.get("Apple");
        System.out.println("Value for key 'Apple': " + value);
    }
}

Map接口是一种键值对的映射表,常用的实现类有HashMapTreeMapHashMap适用于需要快速插入和查找键值对的场景,而TreeMap适用于需要按键的自然顺序或者指定比较器顺序遍历键值对的场景。根据具体的业务需求,我们可以选择合适的Map实现类来存储键值对映射。

💗2. Java集合框架性能优化

虽然Java集合框架提供了丰富的功能,但在处理大数据量时,性能优化变得尤为重要。下面,我们将探讨一些优化技巧,以提高集合框架的性能。

💗2.1 选择合适的集合类型

在选择集合类型时,要根据具体的场景和需求来进行选择。对于频繁的插入和删除操作,使用LinkedList可能比ArrayList更高效。而对于需要频繁查找和快速键值对映射的情况,使用HashMapTreeMap可能更合适。

💗2.2 合理设置容量和负载因子

对于基于散列的集合如HashSetHashMap,初始容量和负载因子的设置会影响其性能。过大的负载因子会导致频繁的rehash操作,而过小的容量则会浪费内存。因此,根据预估的元素数量合理设置容量和负载因子是值得考虑的优化手段。

// 示例代码:设置HashMap的初始容量和负载因子
Map<String, Integer> hashMap = new HashMap<>(1000, 0.75f);

💗2.3 使用并发集合

在多线程环境下,为了保证线程安全性,应该使用并发集合类而不是普通的集合类。例如,ConcurrentHashMap可以在多线程环境下高效地进行插入和查找操作。

// 示例代码:使用ConcurrentHashMap实现线程安全的Map
Map<String, Integer> concurrentHashMap = new ConcurrentHashMap<>();

对于基于散列的集合,如HashSetHashMap,初始容量和负载因子的设置会影响其性能。

容量(Capacity)
容量是指集合在内部存储数据时可以容纳的元素数量。初始容量的设置影响着集合的初始大小,一般来说,设置一个合理的初始容量可以减少扩容操作的次数,从而提高集合的性能。如果预估的元素数量较大,可以适当增大初始容量,以避免频繁的扩容操作,减少性能损耗。但是,设置过大的初始容量也可能浪费内存资源,因此需要根据具体情况进行权衡。

负载因子(Load Factor)
负载因子是指集合在达到多少比例的占用后会触发扩容操作。当集合中的元素数量达到容量乘以负载因子时,集合会自动进行扩容,以保持较低的冲突率。较小的负载因子会导致集合较早扩容,减少冲突,但可能频繁触发扩容操作。较大的负载因子则可以更多地利用内存空间,但可能导致集合中冲突较多,影响查找性能。通常情况下,负载因子的推荐值为0.75,这是一个比较平衡的设置。

因此,在使用HashSetHashMap时,根据预估的元素数量合理设置容量和负载因子是值得考虑的优化手段。合理的设置能够降低rehash操作的频率,提高集合的性能和效率,同时避免浪费内存资源。

💗2.4 注意自定义对象的hashCode()和equals()方法

当我们将自定义对象放入HashSetHashMap时,务必要正确重写对象的hashCode()和equals()方法,以确保它们能够正确地被识别为相等的对象。否则,可能导致相同内容的对象被重复存储。


当我们将自定义对象放入HashSetHashMap时,务必要正确重写对象的hashCode()和equals()方法,以确保它们能够正确地被识别为相等的对象。否则,可能导致相同内容的对象被重复存储。

HashSetHashMap在判断元素是否相等时,依赖于对象的hashCode()和equals()方法。这两个方法在Java中的实现很重要,它们决定了对象在集合中的唯一性。如果没有正确重写这两个方法,可能导致相同内容的对象在集合中被认为是不同的,从而造成重复存储。

为了正确重写hashCode()和equals()方法,我们需要遵循以下规则:

1.hashCode()方法:

  • hashCode()方法返回一个整数,用于表示对象的哈希码。在HashSet和HashMap中,哈希码用于确定对象在内部存储结构中的位置。

  • 如果两个对象通过equals()方法比较相等,那么它们的hashCode()方法应返回相同的值。即,如果a.equals(b)为true,则a.hashCode()应等于b.hashCode()。

  • 如果两个对象通过equals()方法比较不相等,那么它们的hashCode()方法可以返回相同或不同的值。但为了避免哈希冲突,尽量使不相等的对象拥有不同的哈希码。

2.equals()方法:

  • equals()方法用于比较两个对象是否相等。在HashSetHashMap中,用于判断两个键或值是否相等。

  • equals()方法必须满足自反性、对称性、传递性和一致性。也就是说,对于任意非空引用值x、y和z,应满足以下条件:

  • 自反性:x.equals(x)应返回true。

  • 对称性:如果x.equals(y)返回true,则y.equals(x)也应返回true。

  • 传递性:如果x.equals(y)返回true,且y.equals(z)返回true,则x.equals(z)也应返回true。

  • 一致性:对于多次调用x.equals(y),只要对象的内容没有被修改,那么应该保持一致的结果。

正确重写hashCode()和equals()方法,我们可以确保自定义对象在HashSetHashMap中能够正确地被识别为相等的对象,从而避免重复存储,并保证集合的正确性和性能。

💗2.5 避免频繁的集合复制

在处理大数据量时,尽量避免频繁的集合复制操作,因为这会导致不必要的内存消耗和性能损耗。可以通过合理使用集合的addAll()和removeAll()方法来优化复制操作。

// 示例代码:避免频繁的集合复制
List<Integer> sourceList = new ArrayList<>();
List<Integer> targetList = new ArrayList<>();
// 避免这种频繁复制,可以使用addAll()方法
targetList.addAll(sourceList);

addAll()方法:

addAll()方法用于将一个集合中的所有元素添加到另一个集合中。它可以一次性将多个元素添加到目标集合,避免了频繁的单个元素添加操作,从而提高了性能。
当我们需要将一个集合中的元素合并到另一个集合中时,可以使用addAll()方法,避免重复遍历和添加元素的过程。

import java.util.ArrayList;
import java.util.List;

public class CollectionOptimizationDemo {

    public static void main(String[] args) {
        // 示例:使用addAll()方法优化集合复制操作
        List<Integer> sourceList = new ArrayList<>();
        List<Integer> targetList = new ArrayList<>();

        // 假设sourceList和targetList中都有大量的元素
        // 需要将sourceList中的元素合并到targetList中

        // 不优化的复制操作
        for (Integer element : sourceList) {
            targetList.add(element);
        }

        // 优化后的复制操作
        targetList.addAll(sourceList);
    }
}

removeAll()方法:

removeAll()方法用于从一个集合中移除另一个集合中的所有元素。它可以一次性移除多个元素,避免了频繁的单个元素移除操作,从而提高了性能。
当我们需要从一个集合中移除另一个集合中的元素时,可以使用removeAll()方法,避免重复遍历和移除元素的过程。

import java.util.ArrayList;
import java.util.List;

public class CollectionOptimizationDemo {

    public static void main(String[] args) {
        // 示例:使用removeAll()方法优化集合复制操作
        List<Integer> sourceList = new ArrayList<>();
        List<Integer> targetList = new ArrayList<>();

        // 假设sourceList和targetList中都有大量的元素
        // 需要将sourceList中的元素从targetList中移除

        // 不优化的复制操作
        for (Integer element : sourceList) {
            targetList.remove(element);
        }

        // 优化后的复制操作
        targetList.removeAll(sourceList);
    }
}

通过合理使用addAll()和removeAll()方法,我们可以优化集合的复制和移除操作,避免不必要的内存消耗和性能损耗,特别是在处理大数据量的场景下,这种优化手段尤为重要。

💗结论

本博客深度解析了Java集合框架的核心组件,包括Collection接口、List、Set、Queue和Map接口,以及它们的常用实现类。同时,提供了优化技巧和示例,帮助大家更好地理解和应用集合框架。合理选择集合类型、设置容量和负载因子、使用并发集合、注意自定义对象的hashCode()和equals()方法,以及避免频繁的集合复制,都是优化集合框架性能的有效手段。通过这些优化,我们可以更高效地处理大数据量,提升程序的性能和效率。在实际开发中,根据具体需求灵活运用这些技巧,必将为我们带来更好的编程体验。

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

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

相关文章

vue新学习 02 vue命令v-model,数据代理(作用域和作用域链),事件,监听,条件渲染,计算属性(也就是把操作属性的语句放到vue实例中)

双向绑定用命令v-model&#xff1a; v-bind的命令是单项去绑定data中的相关属性&#xff0c;此时的data是真正的data&#xff0c;并没有用变量声明的方式去接收vue实例对象&#xff0c;也就是例如用const vm new Vue({})。而是直接就采用了new Vue&#xff08;{}&#xff09;这…

戴琼海院士——人工智能正深刻地改变这个时代

原创 | 文 BFT机器人 2023世界人工智能大会将继续发挥“科技风向标、应用展示台、产业加速器、治理议事厅”的重要作用&#xff0c;打造“会议论坛、展览展示、评奖赛事、应用体验”四大核心内容&#xff0c;汇聚世界顶级科学家、企业家、政府官员、专家学者、国际组织、投资人…

Ssm+Mysql实现的Java Web酒店管理项目源码附带视频指导运行教程及需求文档

由ssmmysql实现的一款酒店管理系统&#xff0c;该系统实现了酒店客房预订管理的基本功能&#xff0c;还增加了图表显示统计结果的功能有需要的可以联系我分享给大家&#xff0c;下面是运行后的一些截图&#xff1a;

【密码学】四、SM4分组密码算法

SM4分组密码算法 1、概述1.1初始变量算法1.2密钥扩展算法1.3轮函数F1.3.1合成置换T1.3.2S盒 2、算法设计原理2.1非平衡Feistel网络2.2T变换2.2.1非线性变换τ2.2.2线性变换L2.2.3基础置换 2.3密钥扩展算法的设计 1、概述 SM4分组密码算法是一种迭代分组密码算法&#xff0c;采…

使用requests库发送http请求

1. get请求 # 导入requests库 import requests# 此处使用的接口地址为zrlog系统后台登录首页的地址 url "http://172.16.171.129/admin/login"# 通过requests库发送get请求 r requests.get(url url)# 以文本的方式返回响应内容 print(r.text)# 返回HTTP协议状态码…

qssh使用

到官网下载qssh的源码QSsh-botan-1&#xff0c;使用qtcreator打开后&#xff0c;直接编译&#xff0c;即可得到qssh的库 头文件将QSsh-botan-1\src\libs\ssh目录下的.h文件拷到include文件夹下&#xff0c;即为库头文件。 qssh有个问题&#xff0c;如果你将qssh的类放在子线程…

定时发朋友圈怎么设置?

目前微信作为最大的社交平台之一&#xff0c;吸引了众多使用者。你是否听过有些朋友感叹这么多微信号&#xff0c;需要每天手动发布朋友圈&#xff0c;任务很繁琐呢&#xff1f;是否希望可以事先设置好定时发送的功能&#xff0c;让朋友圈自动更新&#xff0c;省去手动发送的麻…

sqlserver row _number函数的运用

sql语句&#xff1a; select dept_id,stcd,row_number() over (partition by dept_id ORDER BY STCD) as 排序 from tb_station_config 这段代码是使用ROW_NUMBER()函数结合窗口函数的语法&#xff0c;用于给结果集中的每一行分配一个唯一的序号。 具体解释如下&#xff1a; R…

uniapp 小程序实时且持续获取定位信息(全局设置一次)(单页面监听定位改变)(不采用定时器)

本篇文章实现了uniapp 微信小程序实时获取定位信息,小程序打开即可持续获取定位信息, 位置更新也会触发相关自定义事件 优点 只设置一次不采用定时器的方式无需多个页面调用单独页面若想获取当前位置是否变化 可单独设置监听,并调用不同逻辑事件 原理: 采用uniapp推出的: un…

基于深度强化学习的DQN模型实现自动玩俄罗斯方块游戏(附详细代码讲解)

一、DQN&#xff08;Deep Q-Network&#xff09;方法概述 DQN&#xff08;Deep Q-Network&#xff09;是一种强化学习方法&#xff0c;通过结合Q-learning算法和深度神经网络来解决强化学习问题。它是深度强化学习的里程碑之一&#xff0c;由DeepMind在2013年提出&#xff0c;被…

【SQL Server】DBCC CHECKDB只是一个数据库维护命令吗?

日期&#xff1a;2023年7月27日 作者&#xff1a;Commas 签名&#xff1a;(ง •_•)ง 积跬步以致千里,积小流以成江海…… 注释&#xff1a;如果您觉得有所帮助&#xff0c;帮忙点个赞&#xff0c;也可以关注我&#xff0c;我们一起成长&#xff1b;如果有不对的地方&#xf…

【数据仓库】Apache Hive初体验

为什么使用Hive&#xff1f; 使用Hadoop MapReduce直接处理数据所面临的问题&#xff1a; 人员学习成本太高需要掌握ava语言MapReduce实现&#xff0c;复杂查询逻辑开发难度太大&#xff01; 1&#xff0c;使用Hive处理数据的好处操作接口采用类SQL语法&#xff0c;提供快速开发…

MUR2080CT- ASEMI二极管的特性和应用

编辑-Z 本文将详细介绍MUR2080CT二极管的特性和应用。首先&#xff0c;将介绍MUR2080CT二极管的基本结构和工作原理。然后&#xff0c;将探讨MUR2080CT二极管的特性&#xff0c;包括正向电压降、反向漏电流和反向恢复时间等。接下来&#xff0c;将介绍MUR2080CT二极管在电源、…

linux环境安装mysql数据库

一&#xff1a;查看是否自带mariadb数据库 命令&#xff1a;rpm -qa | grep mariadb 如果自带数据库则卸载掉重新安装 命令&#xff1a;yum remove mariadb-connector-c-3.1.11-2.el8_3.x86_64 二&#xff1a;将压缩文件上传到/user/local/mysql文件夹 或者直接下载 命令&a…

18款iPad绘画软件推荐!iPad必备生产力工具

每当提起iPad&#xff0c;少不了会听到坊间流传已久的那句话&#xff0c;「买前生产力&#xff0c;买后爱奇艺」&#xff0c;确实有不少奔着生产力入手iPad的人&#xff0c;最终让iPad沦为煲剧神器或泡面盖&#xff0c;但我们没必要因噎废食&#xff0c;因为总有人能克服iPad上…

互联网医院系统源码实现:打造现代化医疗服务平台

摘要 本文将介绍一个基于Python的简化版互联网医院系统的源码实现&#xff0c;主要包含用户注册与登录、医生信息管理、在线预约挂号、在线问诊与咨询、电子病历管理、在线支付与结算等功能。该源码实现仅为示例&#xff0c;实际开发中需要考虑更多的业务逻辑和安全性。 1. …

摄像头m2dock(MAIX-II DOCK)

官方文档地址 https://wiki.sipeed.com/soft/maixpy3/zh/index.html 一、软件准备 1 烧录镜像软件 2 镜像 当前最近版本镜像文件 3 SDFormatter 4 Maixpy IDE 二、SD卡准备 1 格式化SD卡&#xff08;用SDFormatter&#xff09; 2 烧录 3 弹出&#xff0c;插入开发板中 出现…

会议OA项目之待开历史所有会议(使用一个dao方法完成三种会议状态的查询)

&#x1f973;&#x1f973;Welcome Huihuis Code World ! !&#x1f973;&#x1f973; 接下来看看由辉辉所写的关于OA项目的相关操作吧 目录 &#x1f973;&#x1f973;Welcome Huihuis Code World ! !&#x1f973;&#x1f973; 一.主要功能点介绍 二.效果演示 三.前端…

多线程(JavaEE初阶系列5)

目录 前言&#xff1a; 1.什么是定时器 2.标准库中的定时器及使用 3.实现定时器 结束语&#xff1a; 前言&#xff1a; 在上一节中小编给大家介绍了多线程中的两个设计模式&#xff0c;单例模式和阻塞式队列模式&#xff0c;在单例模式中又有两种实现方式一种是懒汉模式&a…

小白如何在简单的分布式锁里反复踩坑

背景 为什么要做分布式锁&#xff1f; Java开发就逃不过多线程问题&#xff0c;而对于单个实例&#xff0c;我们可以使用synchronized锁作为基本的线程锁&#xff0c;解决多线程问题&#xff0c;但对于实际项目中集群部署&#xff0c;分布式系统&#xff08;不同的客户端&…