面试题:JVM 由哪些部分组成?
Java虚拟机(JVM)是一个抽象的计算模型,其实现可以由不同的供应商提供,但所有的实现都遵循Java虚拟机规范。一个典型的JVM主要包括以下几个关键组件: 类加载器子系统(Class Loader Subsyste...
面试题:Java 是如何实现跨平台的?
Java实现跨平台的关键在于其“编写一次,到处运行”(Write Once, Run Anywhere)的设计理念。这一特性主要依赖于以下几个核心技术点: 1. Java虚拟机(JVM) 字节码与JVM:Java源代码首先被编...
面试题:JVM 的 TLAB(Thread-Local Allocation Buffer)是什么?
TLAB(Thread-Local Allocation Buffer,线程本地分配缓冲区)是JVM为了提高对象分配效率而设计的一种机制。它主要用于优化在多线程环境下对堆内存的分配操作。 TLAB的作用 在Java应用中,大多...
面试题:Java 中有哪些垃圾回收算法?
Java中的垃圾回收(GC)机制是自动管理内存的一个重要特性,它通过不同的算法来识别和回收不再使用的对象所占用的内存。以下是几种常见的垃圾回收算法: 标记-清除算法(Mark-Sweep): 这是最...
面试题:为什么 MySQL 索引用的是 B+ 树而不是红黑树?
MySQL 选择 B+ 树作为索引结构而不是红黑树,主要基于以下几个关键原因: 1. 磁盘 I/O 效率 B+ 树是为磁盘存储系统优化的数据结构: 多路平衡查找树:B+ 树的每个节点可以包含多个键值(通常为...
面试题:SQL 中 select、from、join、where、group by、having、order by、limit 的执行顺序是什么?
在 SQL 查询中,虽然我们书写查询语句的顺序是 SELECT, FROM, JOIN, WHERE, GROUP BY, HAVING, ORDER BY, 和 LIMIT,但数据库引擎执行这些操作的实际顺序与书写顺序并不完全相同。以下是SQL查询...
面试题:MySQL 插入一条 SQL 语句,redo log 记录的是什么?
当 MySQL 执行一条插入(INSERT)SQL 语句时,redo log(重做日志)记录的是物理层面的页修改,而不是 SQL 语句本身。具体来说: 1. redo log 记录的内容 redo log 主要记录以下信息: 被修改的...
面试题:MySQL 在设计表(建表)时需要注意什么?
在设计MySQL表(建表)时,有多个方面需要考虑以确保数据库的性能、可维护性和数据完整性。以下是一些关键点: 选择合适的数据类型:为每个字段选择最合适的数据类型非常重要。例如,使用INT而...
面试题:MySQL 三层 B+ 树能存多少数据?
MySQL 三层 B+ 树存储容量分析 要计算 MySQL 中三层 B+ 树能存储多少数据,我们需要考虑以下几个关键因素: 1. B+ 树结构特点 非叶子节点:只存储键值和指针(不存储实际数据) 叶子节点:存储...
面试题:MySQL 事务的二阶段提交是什么?
MySQL中的二阶段提交(Two-Phase Commit, 2PC)是一种用于分布式事务的处理协议,旨在保证分布式系统中多个资源间事务的一致性。 它通常应用于涉及多个数据库实例或存储引擎的情况,以确保所有...