面试题:MySQL 中 DELETE、DROP 和 TRUNCATE 的区别是什么?
在 MySQL 中,DELETE、DROP 和 TRUNCATE 都用于“删除”操作,但它们在 功能、事务支持、性能 以及 对表结构的影响 上有显著区别。以下是详细对比: 1. 核心功能与作用对象 操作核心作用影响范...
场景题:如何实现数据库的不停服迁移?
实现数据库的不停服迁移是许多企业系统升级或架构调整时的核心需求,以下是几种成熟的解决方案: 一、主流迁移方案对比 方案适用场景停机时间复杂度数据一致性保证主从复制版本升级、机房迁移秒...
面试题:Java 线程池内部任务出异常后,如何知道是哪个线程出了异常?
在 Java 中,当你使用线程池(如 ThreadPoolExecutor 或其更高级别的封装如 Executors.newFixedThreadPool() 等)执行任务时,如果任务内部抛出了未捕获的异常,默认情况下这个异常不会直接反馈...
面试题:JVM 由哪些部分组成?
Java虚拟机(JVM)是一个抽象的计算模型,其实现可以由不同的供应商提供,但所有的实现都遵循Java虚拟机规范。一个典型的JVM主要包括以下几个关键组件: 类加载器子系统(Class Loader Subsyste...
场景题:MySQL 中使用索引一定有效吗?如何排查索引效果?
在 MySQL 中,索引并不一定总是有效。虽然索引可以显著加速查询,但在某些场景下,索引可能失效或未被优化器选中。以下是详细分析和排查方法: 一、索引不一定有效的常见原因 1. 查询条件导致索...
面试题:Redis 的订阅发布功能是什么?你了解吗?
Redis 的订阅发布(Pub/Sub,Publisher/Subscriber)功能是一种消息通信模式,允许消息的发送者(发布者)不直接与接收者(订阅者)通信,而是通过频道(channels)进行间接通信。 这种模式非常...
面试题:Redis 支持事务吗?如何实现?
Redis 确实支持事务,它通过 MULTI、EXEC、DISCARD 和 WATCH 四个命令来实现事务功能。以下是 Redis 事务的详细介绍: 一、事务的基本使用 开启事务:使用 MULTI 命令标记一个事务块的开始。一...
面试题:Java 中的 IdentityHashMap 是什么?
IdentityHashMap 是 Java 中 Map 接口的一个特殊实现,位于 java.util 包中。与传统的 HashMap 不同,IdentityHashMap 在比较键是否相等时使用的是对象的引用(reference)而不是对象的内容,也...
面试题:你了解 Java 中的读写锁吗?
是的,Java 中的读写锁(ReadWriteLock)是一种并发控制机制,它允许多个线程同时读取共享资源,但写操作必须独占锁。这种设计在“读多写少”的场景下能显著提高并发性能。以下是关于 Java 中读...
面试题:为什么 Redis Zset 用跳表实现而不是红黑树?B+树?
Redis 的 有序集合(ZSet) 选择使用 跳表(Skip List) 而不是 红黑树(Red-Black Tree) 或 B+树,主要是基于以下多维度的权衡和优化需求。以下是详细分...