排序
面试题:Java ArrayList 的扩容机制是什么?
在 Java 中,ArrayList 是一个基于动态数组的数据结构。由于其内部使用数组来存储元素,因此当添加新元素而现有容量不足以容纳这些元素时,就需要进行扩容操作。以下是 ArrayList 的扩容机制的...
面试题:Java 中 ArrayList 和 LinkedList 有什么区别?
在 Java 中,ArrayList 和 LinkedList 都实现了 List 接口,但它们基于不同的数据结构实现,因此在性能、内存使用和适用场景方面存在显著差异。以下是它们的主要区别: 1. 数据结构基础 ArrayLi...
面试题:为什么 Java 的 ConcurrentHashMap 不支持 key 或 value 为 null?
在 Java 中,ConcurrentHashMap 不允许键(key)或值(value)为 null,这主要是出于对并发访问时的性能优化和避免不确定性行为的考虑。以下是几个主要原因: 避免歧义:如果允许 null 作为键或...
面试题:Java 中的 HashMap 和 Hashtable 有什么区别?
在 Java 中,HashMap 和 Hashtable 都是基于哈希表实现的集合类,用于存储键值对(key-value pairs)。尽管它们有相似之处,但在多个方面存在显著差异。以下是两者的主要区别: 1. 线程安全性 H...
面试题:Java 中的 CopyOnWriteArrayList 是什么?
CopyOnWriteArrayList 是 Java 中的一个线程安全的变体 List,它实现了 List 接口,并且使用了一种独特的机制来处理并发访问的问题。它特别适用于读操作远远多于写操作的场景。 工作原理 写操作...
面试题:Java 的 CopyOnWriteArrayList 和 Collections.synchronizedList 有什么区别?分别有什么优缺点?
CopyOnWriteArrayList 和 Collections.synchronizedList() 都是 Java 中用于实现线程安全的列表操作的方式,但它们的工作机制、适用场景和性能特点有着显著的不同。以下是两者的...
面试题:Java 中 ConcurrentHashMap 的 get 方法是否需要加锁?
在 Java 的 ConcurrentHashMap 中,get 方法的设计旨在保证高效的并发读操作。为了实现这一目标,get 方法在大多数情况下是不需要加锁的。这是通过使用一种称为“无锁算法”的机制来实现的,这...
面试题: ConcurrentHashMap 和 Hashtable 的区别是什么?
ConcurrentHashMap 和 Hashtable 都是 Java 中线程安全的哈希表实现,但它们在实现机制、性能以及使用场景方面存在显著差异。以下是它们的主要区别: 1. 实现方式和锁粒度 Hasht...
面试题:Java 中的 LinkedHashMap 是什么?
LinkedHashMap 是 Java 中 Map 接口的一种实现,它继承自 HashMap 类,并且位于 java.util 包中。LinkedHashMap 不仅保留了 HashMap 的快速查找特性,还通过维护一个双向链表来记录元素的插入顺...
面试题:你遇到过 ConcurrentModificationException 错误吗?它是如何产生的?
ConcurrentModificationException 是 Java 中常见的运行时异常之一,通常在不当修改集合(如 List、Set 或 Map)时抛出。这种错误特别容易在多线程环境下出现,但单线程程序也可能触发它。 如何...