JAVA 中的集合

article/2025/11/7 23:51:14

1.Java中有哪些容器?

Java中的集合主要有两个接口,Map 和 Collection。

Collection接口的子接口有List, Set, Queue。

常见的实现类:

List: LinkedList, ArrayList

Set:HashSet, TreeSet(继承于SortedSet接口)

Queue: ArrayDeque(继承于Deque)

Map: HashMap, HashTable, TreeMap(根据键的大小排序), LinkedHashMap(根据插入顺序排序)

2.容器的线程安全问题

java.util包下的容器大部分是非线程安全的。

线程安全的实现类有HashTable, Vector,这两个类的内部方法是加了synchronized关键字,所以线程安全,但是性能不好,不建议使用。

Collections使用装饰器模式,提供了线程安全的包装类。

JAVA5之后提供juc包, 提供了线程安全的高性能实现类。主要包括三类:Blocking类,Concurrent类,CopyOnWrite类。

Concurrent:

内部很多操作使用 cas 优化,缩小锁粒度等操作

比如jdk1.7的ConcurrentHashMap,分段加锁。 jdk1.8 CAS + synchronized + Node + 红黑树。

ConcurrentLinkedQueue

Blocking :

实现基于锁

BlockingQueue

对队列两端设置dummy结点,然后开头和结尾设置两个锁。同时可以有一个生产者和一个消费者执行。

CopyOnWrite

CopyOnWrite 之类容器修改开销相对较重

CopyOnWrite写入时拷贝的思想, 更改操作会将底层数据拷贝一份,在拷贝上执行修改,不影响其他线程的读操作,读写分离。

CopyOnWriteArrayList

HashMap的并发死链问题

HashMap在扩容的时候创建一个新的数组,容量是原数组的两倍,然后把旧数组的元素重新计算索引位置放入新数组。jdk 1.7的时候发生hash冲突后新元素在链表的头部插入,而1.8之后改为在链表的尾部插入。1.7的情况下如果两个线程都对数组进行扩容可能会导致并发死链,产生链表的循环。

 HashMap为什么用红黑树而不用B树?

红黑树在内存中比b树快, 查找的次数少。但是树的深度大,所以磁盘中不适合用红黑树。

TreeMap的底层原理

TreeMap底层是一个红黑树,根据键的自然顺序或者创建时提供的comparator进行排序

LinkedList和ArrayList的区别

插入,查找,空间有区别。

有哪些线程安全的List

Vector, Collections.SynchronizedList, CopyOnWriteList

ArrayList的底层数据结构

一个数组,初始容量为10, 每次扩容50%。 如果是以append的形式则速度还可以,但是根据index插入会很慢。

HashSet的数据结构

一个HashMap, 值为一个静态常量Object对象, PRESENT。

BlockingQueue中有哪些方法,为什么这样设计?

插入:add                offer                                        put

获取:remove          poll                                         take

        抛异常               返回错误值(超时)                阻塞

TreeMap

TreeMap的实现是红黑树,要使用TreeMap, 元素必须实现comparable接口,或者在构造时传入一个comparator。TreeSet是通过TreeSet实现的。

PriorityQueue

优先级队列使用了一个优雅且高效的数据结构,称为堆(heap)。堆是一 个可以自我调整的二叉树,对树执行添加( add) 和删除(remore) 操作, 可以让最小的元素 移动到根,而不必花费时间对元素进行排序。

需要注意的是,add之后的节点对key进行修改不会对节点重排序。

LinkedHashMap

在一个HashMap的基础上,Entry内部有两个指针,形成双向链表。构造方法可以传入一个boolean accessOrder, true的话就是按照访问顺序排列,false是按照插入顺序排序。 

要实现LRU缓存的话去覆写 boolean : removeEldestEntry, 这个方法在put的时候会被调用,返回true则会删除末尾节点。      

 


http://chatgpt.dhexx.cn/article/Bpvmafge.shtml

相关文章

java中List集合的几种遍历方式

本文中我们给出了List集合中的四种遍历方式&#xff0c;分别是for循环&#xff0c;迭代器循环&#xff0c;代码及相应的注释如下&#xff1a; package d1_collection;import java.util.*;public class cdemo1 {public static void main(String[] args) {List<String> li…

Java中的集合(面试题)

思维导图 1. HashMap排序题, 上机题 已知一个HashMap<Integer, User> 集合,User 有name (String) 和age (int)属性。请写一个方法实现对HashMap的排序功能,该方法接收HashMap <Integer, User>为形参,返回类型为HashMap <Integer, User>,要求对HashMap…

Java中的集合 简述

目录 前言 一、创建集合对象 1、接口怎么创建集合对象 2、实现类怎么创建集合对象 二、不同集合对象的遍历 1、Collection集合的遍历方式之一&#xff1a;Iterator迭代器 2、Set集合的遍历 —— 增强for 3、Map集合的遍历方式一&#xff1a;键找值 4、Map集合的遍历方式二&…

Java中List集合的介绍

List 是什么 JavaList集合是指由JavaList接口以及List接口的所有实现类组成的集合。 List集合中的元素允许重复,各元素的顺序放是对象插入的顺序.类似Java中的数组,用户可通过使用索引(元素在集合中的位置)来访问集合中的元素. 1.Java集合介绍 Java集合就像一个容器&#xff0…

java中的集合 最全面的集合讲解

集合只能存储对象&#xff0c;长度可变的数据结构 Collection是一个接口&#xff0c;没有办法创建对象&#xff0c;所以需要它的子类来创建对象&#xff0c;创建对象的时候可以使用多态。 一、Collection中通用的方法 方法&#xff1a; 创建集合对象&#xff0c;会自动重写t…

Java中List集合与Set集合

目录 一、List 集合 1、List 接口特点 2、List 接口中常用的方法 3、List 集合存储数据结构 4、ArrayList 集合ArrayList 集合是最常用的集合&#xff0c;是用存储数据结构&#xff0c;元素增删慢&#xff0c;查找快。 5、LinkedList 集合 6、Vector 集合 二、Set 接口…

Java中的集合类

Java中所有的类都位于java.util包下&#xff0c;主要由两个接口派生出来。分别是Collection&#xff08;集合&#xff09;和Map.Collection&#xff08;映射集合&#xff09;&#xff0c;包含了List和Set两大分支。Map是一个映射接口。Set、Map、List&#xff08;集&#xff0c…

java中的集合详解

Collection接口和Map接口 1 Collection集合 1.1 集合概述 集合&#xff1a;集合是java中提供的一种容器&#xff0c;可以用来存储多个数据。集合和数组既然都是容器&#xff0c;它们有啥区别呢&#xff1f; 数组的长度是固定的。集合的长度是可变的。 数组中存储的是同一类型的…

java中的集合

1.集合概述 Java的集合框架是由很多接口、抽象类、具体类组成的&#xff0c;都位于java.util包中。 2.Collection接口 Collection 接口&#xff0d;定义了存取一组对象的方法&#xff0c;其子接口Set和List分别定义了存储方式。Set 中的数据对象没有顺序且不可以重复。 List…

Java——集合(超详细超级全)

集合 Java 集合类可以用于存储数量不等的多个对象&#xff0c;还可用于保存具有映射关系的关联数组。 在这里主要讲一些我们平常很常用的一些接口和一些实现类。 Java 集合可分为 Collection 和 Map 两种体系&#xff1a; Collection接口&#xff1a;单列数据&#xff0c;定…

java集合(超详细)

1 - 概述 所有的集合类和集合接口都在java.util包下。 在内存中申请一块空间用来存储数据&#xff0c;在Java中集合就是替换掉定长的数组的一种引用数据类型。 2 - 集合与数组的区别 长度区别 数组长度固定&#xff0c;定义长了造成内存空间的浪费&#xff0c;定义短了不够用…

java创建多线程的方法

Java中是可以创建多个线程的&#xff0c;每个线程都有自己的名字和时间戳。下面我们来看看创建多个线程的方法。 创建多个线程&#xff0c;需要使用到 Thread类中的 create方法。需要注意的是&#xff0c;不是所有的线程都可以使用 create方法来创建&#xff0c;只有当这些线程…

Java创建多线程的五种方法

Java创建多线程的五种方法 Java创建多线程的五种方法&#xff08;一&#xff09;继承Thread类1&#xff0e;实现描述2&#xff0e;具体步骤3&#xff0e;代码实现4&#xff0e;注意事项 &#xff08;二&#xff09;实现Runnable接口1&#xff0e;实现描述2&#xff0e;具体步骤…

Java创建线程(Lambda表达式创建线程)

一、创建线程三种方式 1.1 继承Thread类创建线程类&#xff08;main线程与t线程交替执行&#xff09; 1.2 通过Runnable接口创建线程类 弊端是:不能直接使用Thread中的方法需要先获取到线程对象后,才能得到Thread的方法,代码复杂 上述代码中Thread.currentThread()方法返回当…

java创建线程的四种方法

第一种: 通过继承Thread类创建线程 第二种: 通过实现Runnable接口创建线程 这两种早已烂记于心,这里就不作过多的介绍, 主要介绍其源码 Thread类 implements Runnable thread空线程的run方法 是判断target是否存在实,再执行target实例中的run方法 public void run(){if(th…

Java创建线程

目录 既然说到线程&#xff0c;在这里就给大家普及一下线程。 线程&#xff08;Thread&#xff09;&#xff1a; 那么&#xff0c;进程是什么呢&#xff1f; 接下来&#xff0c;就让我们步入主题&#xff1a; 在 Java 中&#xff0c;是这样说线程的&#xff1a; 创建一个新…

Java创建多线程的8种方式

目录 1、继承Thread类&#xff0c;重写run()方法 2、实现Runnable接口&#xff0c;重写run() 3、匿名内部类的方式 4、带返回值的线程(实现implements Callable<返回值类型>)————以上3种方式&#xff0c;都没有返回值且都无法抛出异常。 5、定时器(java.util.Timer)…

java如何创建线程

java如何创建线程 1. java如何创建线程1.1 通过继承Thread类来创建线程1.2 通过实现Runnable接口来创建线程1.3 通过匿名内部类来创建线程1.4 lambda表达式1.5 通过实现Runnable接口的方式创建线程目标类的优缺点 1. java如何创建线程 一个线程在Java中使用一个Thread实例来描…

Java多线程 - Java创建线程的4种方式

文章目录 1. Java创建线程有哪几种方式&#xff1f;1.1 线程创建方法一&#xff1a;继承Thread类创建线程类1.2 线程创建方法二&#xff1a;实现Runnable接口创建线程目标类1.5 线程创建方法三&#xff1a;使用Callable和FutureTask创建线程1.6 线程创建方法四&#xff1a;通过…

java创建线程的四种方式

1&#xff09;继承Thread类创建线程 如图所示: //继承Thread类 class Aclass extends Thread{//输出100以内的偶数Overridepublic void run() {for (int i 1; i <100; i) {System.out.println(getName()":"i);}} } 测试: Thread t1 new Aclass();t1.setName…