面试题:什么是 Java 的 happens-before 规则?
在Java中,happens-before 规则是Java内存模型(JMM, Java Memory Model)的一部分,用于定义程序中操作之间的部分有序关系,确保多线程环境下的可见性和顺序性。 通过这些规则,程序员可以确定...
面试题:MySQL 的乐观锁和悲观锁是什么?
在 MySQL 中,乐观锁和悲观锁是两种处理并发控制的方法,它们分别适用于不同的场景,并以不同的方式来保证数据的一致性和完整性。 悲观锁(Pessimistic Locking) 概念:悲观锁假设会发生并发冲...
面试题:Java 中静态方法和实例方法的区别是什么?
在Java中,静态方法和实例方法是两种不同类型的方法,它们在定义、调用方式以及使用场景上都有显著的区别。以下是它们之间的主要差异: 1. 定义与声明 静态方法:使用static关键字来声明。这意...
面试题:Java 中的 final 关键字是否能保证变量的可见性?
在Java中,final 关键字主要用于三种场景:变量、方法和类。对于 final 变量,它确实能间接地提供某种程度的可见性保证,但这并不是它的主要目的。 final 关键字的作用 不可变性:当一个变量被...
面试题:Java 中 ConcurrentHashMap 的 get 方法是否需要加锁?
在 Java 的 ConcurrentHashMap 中,get 方法的设计旨在保证高效的并发读操作。为了实现这一目标,get 方法在大多数情况下是不需要加锁的。这是通过使用一种称为“无锁算法”的机制来实现的,这...
面试题:MySQL 中 INNER JOIN、LEFT JOIN 和 RIGHT JOIN 的区别是什么?
在 MySQL 中,INNER JOIN、LEFT JOIN 和 RIGHT JOIN 是常用的表连接方式,它们的核心区别在于如何处理 匹配和未匹配的记录。以下是详细对比: 1. INNER JOIN(内连接) 定...
面试题:Java 中的 CMS 和 G1 垃圾收集器如何维持并发的正确性?
CMS(Concurrent Mark-Sweep)和 G1(Garbage First)垃圾收集器在Java中通过不同的机制来维持并发操作的正确性,即确保在应用程序线程与垃圾收集器线程同时运行时不会导致数据不一致或错误。 ...
面试题:什么是 Java 的 Semaphore?
Java 中的 Semaphore 是 java.util.concurrent 包提供的一个资源访问控制工具类,用于限制同时访问的线程数量,从而实现对共享资源的并发控制。它是基于 AQS(AbstractQueuedSynchronizer) 实...
面试题:MySQL 中的 Log Buffer 是什么?它有什么作用?
1. Log Buffer 的定义 Log Buffer(日志缓冲区)是 MySQL InnoDB 存储引擎 中的一个关键内存区域,用于临时存储事务的 Redo Log(重做日志)。当事务对数据库执行修改操作(如 I...
面试题:如何使用 Redis 快速实现布隆过滤器?
布隆过滤器(Bloom Filter)是一种空间效率非常高的概率型数据结构,主要用于判断一个元素是否在一个集合中。 它的优点是可以用很小的内存代价来表示很大的集合,并且插入和查询的时间复杂度都...