Java常见面试题及答案汇总(2025持续更新)

Java 作为企业级开发的主流语言,面试时涉及的知识点广泛且深入。本文整理了 Java 基础、集合、多线程、JVM、Spring、数据库、分布式 等高频面试题,并附上详细解析,帮助大家高效备战面试!


📚 一、Java 基础

1. Java 的三大特性是什么?

✅ 答案:

  • 封装:隐藏对象的属性和实现细节,仅对外提供访问方式(getter/setter)。
  • 继承:子类继承父类的属性和方法,提高代码复用性。
  • 多态:同一方法在不同对象上有不同行为(方法重写、接口实现)。

2. == 和 equals() 的区别?

✅ 答案:

  • ==:比较基本数据类型的值,或引用类型的内存地址。
  • equals():默认比较对象地址(Object类),但可被重写(如 String 比较内容)。

3. String、StringBuilder、StringBuffer 的区别?

✅ 答案:

可变性线程安全适用场景
String❌ 不可变✅ 安全(final)字符串常量
StringBuilder✅ 可变❌ 不安全单线程字符串操作
StringBuffer✅ 可变✅ 安全(synchronized)多线程字符串操作

🔍 二、Java 集合

4. ArrayList 和 LinkedList 的区别?

✅ 答案:

对比项ArrayListLinkedList
底层结构动态数组双向链表
查询效率O(1)(随机访问快)O(n)(需遍历)
增删效率O(n)(需移动元素)O(1)(头尾操作快)
适用场景频繁查询频繁增删

5. HashMap 的底层原理?

✅ 答案:

  • JDK 1.7:数组 + 链表(哈希冲突时链表存储)。
  • JDK 1.8+:数组 + 链表 + 红黑树(链表长度 ≥8 时转红黑树)。
  • 扩容机制:默认容量 16,负载因子 0.75,扩容时容量翻倍。

⚡ 三、多线程 & 并发

6. 线程的创建方式有哪些?

✅ 答案:

  1. 继承 Thread 类(不推荐,单继承限制)。
  2. 实现 Runnable 接口(推荐,可复用)。
  3. 实现 Callable 接口(可返回结果,配合 FutureTask)。
  4. 线程池(ExecutorService)(推荐,管理线程资源)。

7. synchronized 和 ReentrantLock 的区别?

✅ 答案:

对比项synchronizedReentrantLock
实现方式JVM 层面Java API 层面
锁类型非公平锁可公平/非公平
可中断❌ 不支持✅ 支持(lockInterruptibly)
条件变量❌ 不支持✅ 支持(Condition)

🛠️ 四、JVM

8. JVM 内存模型(运行时数据区)?

✅ 答案:

  • 方法区(元空间):存储类信息、常量、静态变量。
  • 堆(Heap):存放对象实例(GC 主要区域)。
  • 虚拟机栈:存储方法调用、局部变量表。
  • 本地方法栈:Native 方法调用。
  • 程序计数器:记录线程执行位置。

9. 垃圾回收算法有哪些?

✅ 答案:

  • 标记-清除:简单但内存碎片多。
  • 复制算法:高效(新生代使用),但浪费空间。
  • 标记-整理:适合老年代,减少碎片。
  • 分代收集:新生代(复制算法) + 老年代(标记-整理)。

🌱 五、Spring

10. Spring Bean 的生命周期?

✅ 答案:

  1. 实例化(new)
  2. 属性赋值(populate)
  3. 初始化@PostConstructInitializingBean
  4. 使用
  5. 销毁@PreDestroyDisposableBean

11. Spring AOP 的实现原理?

✅ 答案:

  • JDK 动态代理(基于接口)。
  • CGLIB 动态代理(基于子类,无接口时使用)。
  • 核心:ProxyFactory + MethodInterceptor

📊 六、数据库 & 缓存

12. MySQL 索引失效的场景?

✅ 答案:

  • 使用 !=<>NOT IN
  • 对索引列进行运算(如 WHERE age + 1 > 20)。
  • 使用 LIKE '%xx'(左模糊)。
  • 联合索引未遵循最左前缀原则。

13. Redis 持久化方式?

✅ 答案:

  • RDB(快照):定时全量备份,恢复快但可能丢数据。
  • AOF(日志):记录写命令,数据更安全但文件较大。
  • 混合模式(Redis 4.0+):RDB + AOF 结合。

🚀 七、分布式 & 微服务

14. CAP 理论是什么?

✅ 答案:

  • C(一致性):所有节点数据一致。
  • A(可用性):每次请求都能响应。
  • P(分区容错性):网络分区时仍能运行。
  • 结论:分布式系统只能满足其中两项(如 CP、AP)。

15. 如何解决分布式事务问题?

✅ 答案:

  • 2PC(两阶段提交):协调者 + 参与者,强一致但阻塞。
  • TCC(Try-Confirm-Cancel):业务补偿,适用于高并发。
  • SAGA:长事务拆分 + 补偿机制。
  • 本地消息表:异步确保最终一致。

🎯 总结

本文整理了 Java 面试高频问题,涵盖 基础、集合、并发、JVM、Spring、数据库、分布式 等核心知识点,适合 校招 & 社招 备战!

💡 建议收藏 + 实践 + 深入理解原理!

📌 你的点赞和关注是我持续更新的动力! 🚀

📢 欢迎在评论区补充你的面试经验! 💬

Read more

华为OD技术面八股文_C++_01

华为OD技术面八股文_C++_01

文章目录 * C语言和C++的区别 * C++11引入哪些新特性 * 什么是面向对象?面向对象的三大特性 * malloc和new的区别 * delete和free的区别 * delete和delete[]的区别 * 什么是虚函数?什么是纯虚函数 * 什么是虚函数表?什么是虚函数指针? * 介绍一下虚函数实现机制 * 构造函数和构析函数能不能写为虚函数,为什么 * 说一下构造、析构函数的调用顺序 C语言和C++的区别 1. C++有新增的关键字和语法,还允许自定义命名空间。 2. C++新增类的概念,C语言中只有struct的概念。C++中添加访问权限概念,struct 的默认访问权限和继承权限都是 public,但是 class 的默认访问权限和默认继承权限都是 private. 3. C++引入了类、封装、继承、多态、模板、重载、异常处理机制等特性。而C没有 4.

By Ne0inhk
C++可变参数队列与压栈顺序:从模板语法到汇编调用约定的深度解析

C++可变参数队列与压栈顺序:从模板语法到汇编调用约定的深度解析

C++可变参数队列与压栈顺序:从模板语法到汇编调用约定的深度解析 本文聚焦一个具体而关键的技术主题:C++ 可变参数模板(Variadic Templates)。我们将从现代 C++ 的优雅写法出发,深入剖析其在 x86-64 架构下的真实行为,特别澄清一个长期被误解的核心问题——可变参数是否“从右向左压栈”?它们在寄存器和栈中究竟是如何排布的? 如果你正在实现一个类型安全的消息队列、日志系统或任务调度器,并希望理解 enqueue(1, "hello", 3.14) 这行代码在 CPU 层面到底发生了什么,那么这篇文章就是为你量身打造的。 一、引言:可变参数 ≠ va_list —— 一场范式革命 很多初学者将 C++ 的可变参数模板与 C 语言的 va_list 混为一谈。这是重大误区,甚至会导致错误的性能假设和安全漏洞。 1.1

By Ne0inhk
《C++ Stack 与 Queue 完全使用指南:基础操作 + 经典场景 + 实战习题》

《C++ Stack 与 Queue 完全使用指南:基础操作 + 经典场景 + 实战习题》

🔥草莓熊Lotso:个人主页 ❄️个人专栏: 《C++知识分享》《Linux 入门到实践:零基础也能懂》 ✨生活是默默的坚持,毅力是永久的享受! 🎬 博主简介: 文章目录 * 前言: * 一. 先搞懂基础:Stack 与 Queue 的核心特性 * 二. Stack(栈):后进先出(LIFO)的容器 * 2.1 核心特性: * 2.2 头文件与定义 * 2.3 常用接口全解析 * 2.4 基础用法演示 * 三. Queue(队列):先进先出(FIFO)的容器 * 3.1 核心特性: * 3.2 头文件与定义: * 3.

By Ne0inhk
【C++】第十七节—二叉搜索树(概念+性能分析+增删查+实现+使用场景)

【C++】第十七节—二叉搜索树(概念+性能分析+增删查+实现+使用场景)

好久不见,我是云边有个稻草人 《C++》本文所属专栏—持续更新中—欢迎订阅 目录 一、二叉搜索树的概念 二、二叉搜索树的性能分析 三、二叉搜索树的插入 SearchBinaryTree.h test.cpp 四、⼆叉搜索树的查找 【只有一个3】 【有多个3】  五、⼆叉搜索树的删除 六、二叉搜索树的实现代码 SearchBinaryTree.h test.cpp  七、二叉搜索树key和key/value使用场景 7.1 key搜索场景 7.2 key/value搜索场景 7.3 key/value⼆叉搜索树代码实现 .h .cpp 正文开始—— 一、二叉搜索树的概念 ⼆叉搜索树⼜

By Ne0inhk