写点什么

2022 年最新【Java 经典面试 800 题】面试必备,查漏补缺;多线程 +spring+JVM 调优 + 分布式 +redis+ 算法

作者:Geek_Yin
  • 2022 年 8 月 23 日
    湖南
  • 本文字数:6344 字

    阅读完需:约 21 分钟

2022年最新【Java经典面试800题】面试必备,查漏补缺;多线程+spring+JVM调优+分布式+redis+算法

前言

春招,秋招,社招,我们 Java 程序员的面试之路,是挺难的,过了 HR,还得被技术面,小刀在去各个厂面试的时候,经常是通宵睡不着觉,头发都脱了一大把,还好最终侥幸能够入职一个独角兽公司,安稳从事喜欢的工作至今...

近期也算是抽取出大部分休息的时间,为大家准备了一份通往大厂面试的小捷径,准备了一整套 Java 复习面试的刷题以及答案,我知道很多同学不知道怎么复习,不知道学习过程中哪些才是重点,其实,你们经历过的事情,小马也经历过,正应为经历过,所以不愿意看到还有万千学子为此伤神,也许这篇文章帮不到万千学子,但是能够在 infoq 这个平台上帮助到正在看这篇文章的那个迷茫的你! 我也就满足了!

我也花费好几个月收集整理了各大厂常见面试题 N 道,你想要的这里都有内容涵盖:Java、MyBatis、ZooKeeper、Dubbo、Elasticsearch、Memcached、Redis、MySQL、Spring、Spring Boot、Spring Cloud、RabbitMQ、Kafka、Linux 等技术栈!!!

耗时 45 天才整理出《Java 核心笔记》,足足 5000 页,已全部打包在网盘里了,有需要的读者朋友们在文末获取详情~


具体面试题如下:

一、Java 基础

  • 1. JDK 和 JRE 有什么区别?

  • 2. == 和 equals 的区别是什么?

  • 3. 两个对象的 hashCode()相同,则 equals()也一定为 true,对吗?

  • 4. final 在 java 中有什么作用?

  • 5. java 中的 Math.round(-1.5) 等于多少?

  • 6. String 属于基础的数据类型吗?

  • 7. java 中操作字符串都有哪些类?它们之间有什么区别?

  • 8. String str="i"与 String str=new String(“i”)一样吗?

  • 9. 如何将字符串反转?

  • 10. String 类的常用方法都有那些?

  • 11. 抽象类必须要有抽象方法吗?

  • 12. 普通类和抽象类有哪些区别?

  • 13. 抽象类能使用 final 修饰吗?

  • 14. 接口和抽象类有什么区别?

  • 15. java 中 IO 流分为几种?

  • 16. BIO、NIO、AIO 有什么区别?

  • 17. Files 的常用方法都有哪些?

二、容器

  • 18. java 容器都有哪些?

  • 19. Collection 和 Collections 有什么区别?

  • 20. List、Set、Map 之间的区别是什么?

  • 21. HashMap 和 Hashtable 有什么区别?

  • 22. 如何决定使用 HashMap 还是 TreeMap?

  • 23. 说一下 HashMap 的实现原理?

  • 24. 说一下 HashSet 的实现原理?

  • 25. ArrayList 和 LinkedList 的区别是什么?

  • 26. 如何实现数组和 List 之间的转换?

  • 27. ArrayList 和 Vector 的区别是什么?

  • 28. Array 和 ArrayList 有何区别?

  • 29. 在 Queue 中 poll()和 remove()有什么区别?

  • 30. 哪些集合类是线程安全的?

  • 31. 迭代器 Iterator 是什么?

  • 32. Iterator 怎么使用?有什么特点?

  • 33. Iterator 和 ListIterator 有什么区别?

  • 34. 怎么确保一个集合不能被修改?

三、多线程

  • 35. 并行和并发有什么区别?

  • 36. 线程和进程的区别?

  • 37. 守护线程是什么?

  • 38. 创建线程有哪几种方式?

  • 39. 说一下 runnable 和 callable 有什么区别?

  • 40. 线程有哪些状态?

  • 41. sleep() 和 wait() 有什么区别?

  • 42. notify()和 notifyAll()有什么区别?

  • 43. 线程的 run()和 start()有什么区别?

  • 44.创建线程池有哪几种方式?

  • 45.线程池都有哪些状态?

  • 46. 线程池中 submit()和 execute()方法有什么区别?

  • 47. 在 java 程序中怎么保证多线程的运行安全?

  • 48. 多线程锁的升级原理是什么?

  • 49. 什么是死锁?

  • 50. 怎么防止死锁?

  • 51. ThreadLocal 是什么?有哪些使用场景?

  • 52. 说一下 synchronized 底层实现原理?

  • 53. synchronized 和 volatile 的区别是什么?

  • 54. synchronized 和 Lock 有什么区别?

  • 55. synchronized 和 ReentrantLock 区别是什么?

  • 56. 说一下 atomic 的原理?

四、反射

  • 57. 什么是反射?

  • 58. 什么是 java 序列化?什么情况下需要序列化?

  • 59. 动态代理是什么?有哪些应用?

  • 60. 怎么实现动态代理?

五、对象拷贝

  • 61. 为什么要使用克隆?

  • 62. 如何实现对象克隆?

  • 63. 深拷贝和浅拷贝区别是什么?

六、Java Web

  • 64. jsp 和 servlet 有什么区别?

  • 65. jsp 有哪些内置对象?作用分别是什么?

  • 66. 说一下 jsp 的 4 种作用域?

  • 67. session 和 cookie 有什么区别?

  • 68. 说一下 session 的工作原理?

  • 69. 如果客户端禁止 cookie 能实现 session 还能用吗?

  • 70. spring mvc 和 struts 的区别是什么?

  • 71. 如何避免 sql 注入?

  • 72. 什么是 XSS 攻击,如何避免?

  • 73. 什么是 CSRF 攻击,如何避免?

七、异常

  • 74. throw 和 throws 的区别?

  • 75. final、finally、finalize 有什么区别?

  • 76. try-catch-finally 中哪个部分可以省略?

  • 77. try-catch-finally 中,如果 catch 中 return 了,finally 还会执行吗?

  • 78. 常见的异常类有哪些?

八、网络

  • 79. http 响应码 301 和 302 代表的是什么?有什么区别?

  • 80. forward 和 redirect 的区别?

  • 81. 简述 tcp 和 udp 的区别?

  • 82. tcp 为什么要三次握手,两次不行吗?为什么?

  • 83. 说一下 tcp 粘包是怎么产生的?

  • 84. OSI 的七层模型都有哪些?

  • 85. get 和 post 请求有哪些区别?

  • 86. 如何实现跨域?

  • 87. 说一下 JSONP 实现原理?

九、设计模式

  • 88. 说一下你熟悉的设计模式?

  • 89. 简单工厂和抽象工厂有什么区别?

十、Spring/Spring MVC

  • 90. 为什么要使用 spring?

  • 91. 解释一下什么是 aop?

  • 92. 解释一下什么是 ioc?

  • 93. spring 有哪些主要模块?

  • 94. spring 常用的注入方式有哪些?

  • 95. spring 中的 bean 是线程安全的吗?

  • 96. spring 支持几种 bean 的作用域?

  • 97. spring 自动装配 bean 有哪些方式?

  • 98. spring 事务实现方式有哪些?

  • 99. 说一下 spring 的事务隔离?

  • 100. 说一下 spring mvc 运行流程?

  • 101. spring mvc 有哪些组件?

  • 102. @RequestMapping 的作用是什么?

  • 103. @Autowired 的作用是什么?

十一、Spring Boot/Spring Cloud

  • 104. 什么是 spring boot?

  • 105. 为什么要用 spring boot?

  • 106. spring boot 核心配置文件是什么?

  • 107. spring boot 配置文件有哪几种类型?它们有什么区别?

  • 108. spring boot 有哪些方式可以实现热部署?

  • 109. jpa 和 hibernate 有什么区别?

  • 110. 什么是 spring cloud?

  • 111. spring cloud 断路器的作用是什么?

  • 112. spring cloud 的核心组件有哪些?

十二、Hibernate

  • 113. 为什么要使用 hibernate?

  • 114. 什么是 ORM 框架?

  • 115. hibernate 中如何在控制台查看打印的 sql 语句?

  • 116. hibernate 有几种查询方式?

  • 117. hibernate 实体类可以被定义为 final 吗?

  • 118. 在 hibernate 中使用 Integer 和 int 做映射有什么区别?

  • 119. hibernate 是如何工作的?

  • 120. get()和 load()的区别?

  • 121. 说一下 hibernate 的缓存机制?

  • 122. hibernate 对象有哪些状态?

  • 123. 在 hibernate 中 getCurrentSession 和 openSession 的区别是什么?

  • 124. hibernate 实体类必须要有无参构造函数吗?为什么?

十三、Mybatis

  • 125. mybatis 中 #{}和 ${}的区别是什么?

  • 126. mybatis 有几种分页方式?

  • 127. RowBounds 是一次性查询全部结果吗?为什么?

  • 128. mybatis 逻辑分页和物理分页的区别是什么?

  • 129. mybatis 是否支持延迟加载?延迟加载的原理是什么?

  • 130. 说一下 mybatis 的一级缓存和二级缓存?

  • 131. mybatis 和 hibernate 的区别有哪些?

  • 132. mybatis 有哪些执行器(Executor)?

  • 133. mybatis 分页插件的实现原理是什么?

  • 134. mybatis 如何编写一个自定义插件?

十四、RabbitMQ

  • 135. rabbitmq 的使用场景有哪些?

  • 136. rabbitmq 有哪些重要的角色?

  • 137. rabbitmq 有哪些重要的组件?

  • 138. rabbitmq 中 vhost 的作用是什么?

  • 139. rabbitmq 的消息是怎么发送的?

  • 140. rabbitmq 怎么保证消息的稳定性?

  • 141.rabbitmq 怎么避免消息丢失?

  • 142. 要保证消息持久化成功的条件有哪些?

  • 143. rabbitmq 持久化有什么缺点?

  • 144. rabbitmq 有几种广播类型?

  • 145. rabbitmq 怎么实现延迟消息队列?

  • 146. rabbitmq 集群有什么用?

  • 147. rabbitmq 节点的类型有哪些?

  • 148. rabbitmq 集群搭建需要注意哪些问题?

  • 149. rabbitmq 每个节点是其他节点的完整拷贝吗?为什么?

  • 150. rabbitmq 集群中唯一一个磁盘节点崩溃了会发生什么情况?

  • 151. rabbitmq 对集群节点停止顺序有要求吗?

十五、Kafka

  • 152. kafka 可以脱离 zookeeper 单独使用吗?为什么?

  • 153. kafka 有几种数据保留的策略?

  • 154. kafka 同时设置了 7 天和 10G 清除数据,到第五天的时候消息达到了 10G,这个时候 kafka 将如何处理?

  • 155. 什么情况会导致 kafka 运行变慢?

  • 156. 使用 kafka 集群需要注意什么?

十六、Zookeeper

  • 157. zookeeper 是什么?

  • 158. zookeeper 都有哪些功能?

  • 159. zookeeper 有几种部署模式?

  • 160. zookeeper 怎么保证主从节点的状态同步?

  • 161. 集群中为什么要有主节点?

  • 162. 集群中有 3 台服务器,其中一个节点宕机,这个时候 zookeeper 还可以使用吗?

  • 163. 说一下 zookeeper 的通知机制?

十七、MySql

  • 164. 数据库的三范式是什么?

  • 165. 一张自增表里面总共有 7 条数据,删除了最后 2 条数据,重启 mysql 数据库,又插入了一条数据,此时 id 是几?

  • 166. 如何获取当前数据库版本?

  • 167. 说一下 ACID 是什么?

  • 168. char 和 varchar 的区别是什么?

  • 169. float 和 double 的区别是什么?

  • 170. mysql 的内连接、左连接、右连接有什么区别?

  • 171. mysql 索引是怎么实现的?

  • 172. 怎么验证 mysql 的索引是否满足需求?

  • 173. 说一下数据库的事务隔离?

  • 174. 说一下 mysql 常用的引擎?

  • 175. 说一下 mysql 的行锁和表锁?

  • 176. 说一下乐观锁和悲观锁?

  • 177. mysql 问题排查都有哪些手段?

  • 178. 如何做 mysql 的性能优化?

十八、Redis

  • 179. redis 是什么?都有哪些使用场景?

  • 180. redis 有哪些功能?

  • 181. redis 和 memecache 有什么区别?

  • 182. redis 为什么是单线程的?

  • 183. 什么是缓存穿透?怎么解决?

  • 184. redis 支持的数据类型有哪些?

  • 185. redis 支持的 java 客户端都有哪些?

  • 186. jedis 和 redisson 有哪些区别?

  • 187. 怎么保证缓存和数据库数据的一致性?

  • 188. redis 持久化有几种方式?

  • 189.redis 怎么实现分布式锁?

  • 190. redis 分布式锁有什么缺陷?

  • 191. redis 如何做内存优化?

  • 192. redis 淘汰策略有哪些?

  • 193. redis 常见的性能问题有哪些?该如何解决?

十九、JVM

  • 194. 说一下 jvm 的主要组成部分?及其作用?

  • 195. 说一下 jvm 运行时数据区?

  • 196. 说一下堆栈的区别?

  • 197. 队列和栈是什么?有什么区别?

  • 198. 什么是双亲委派模型?

  • 199. 说一下类加载的执行过程?

  • 200. 怎么判断对象是否可以被回收?

  • 201. java 中都有哪些引用类型?

  • 202. 说一下 jvm 有哪些垃圾回收算法?

  • 203. 说一下 jvm 有哪些垃圾回收器?

  • 204. 详细介绍一下 CMS 垃圾回收器?

  • 205. 新生代垃圾回收器和老生代垃圾回收器都有哪些?有什么区别?

  • 206. 简述分代垃圾回收器是怎么工作的?

  • 207. 说一下 jvm 调优的工具?

  • 208. 常用的 jvm 调优的参数都有哪些?

我们与其羡慕他人的成功,不如从此刻开始,积累足够多的知识和面试经验,为将来进入更好的公司做充分的准备!机会永远属于有准备的人~希望大家学完之后,都能拿到自己心仪的 Offer!!

Java 核心笔记目录:

由于题量较多,篇幅的限制,文章中的面试题分享没有全部附上详细的解析,但是整理成了一份详细的 PDF 文档可分享给大家

看面试题可以是为了面试,也可以是对自己学到的东西的一种查漏补缺,更加深刻的去了解一些核心知识点

MyBatis 面试题

  • 1、什么是 Mybatis?

  • 2、Mybaits 的优点:

  • 3、MyBatis 框架的缺点:

  • 4、MyBatis 框架适用场合:

  • 5、MyBatis 与 Hibernate 有哪些不同?

  • 6、#{}和 ${}的区别是什么?

  • 7、当实体类中的属性名和表中的字段名不一样 ,怎么办 ?

  • 8、 模糊查询 like 语句该怎么写?



ZooKeeper 面试题

ZooKeeper 是一个开源的分布式协调服务,由雅虎创建,是 Google Chubby 的开源实现。分布式应用程序可以基于 ZooKeeper 实现诸如数据发布/订阅、负载均衡、命名服务、分布式协调/通知、集群管理、Master 选举、配置维护,名字服务、分布式同步、分布式锁和分布式队列等功能。

  • zookeeper 负载均衡和 nginx 负载均衡区别

  • Zookeeper Watcher 机制--数据变更通知

  • 客户端注册 Watcher 实现

  • zookeeper 是如何保证事务的顺序一致性的?

  • Zookeeper 对节点的 watch 监听通知是永久的吗?为什么不是永久的?

  • zk 节点宕机如何处理?

Zookeeper 本身也是集群,推荐配置不少于 3 个服务器。Zookeeper 自身也要保证当一个节点宕机时,其他节点会继续提供服务。如果是一个 Follower 宕机,还有 2 台服务器提供访问,因为 Zookeeper 上的数据是有多个副本的,数据并不会丢失;如果是一个 Leader 宕机,Zookeeper 会选举出新的 Leader。ZK 集群的机制是只要超过半数的节点正常,集群就能正常提供服务。只有在 ZK 节点挂得太多,只剩一半或不到一半节点能工作,集群才失效。所以 3 个节点的 cluster 可以挂掉 1 个节点(leader 可以得到 2 票>1.5)2 个节点的 cluster 就不能挂掉任何 1 个节点了(leader 可以得到 1 票<=1)..........

Dubbo 面试题

Spring Eureka 从开源转变为闭源,Consul 正在崛起,而 Dubbo 又开始重新更新。目前市场上仍有不少公司使用 dubbo 我们也需要继续学习。

  • 为什么要用 Dubbo?

  • 默认使用的是什么通信框架,还有别的选择吗?

  • 服务调用是阻塞的吗?

  • 一般使用什么注册中心?还有别的选择吗?

  • 默认使用什么序列化框架,你知道的还有哪些?

  • Dubbo 的整体架构设计有哪些分层?

...............

Elasticsearch 面试题

  • elasticsearch 了解多少,说说你们公司 es 的集群架构,索引数据大小,分片有多少,以及一些调优手段 。

  • elasticsearch 索引数据多了怎么办,如何调优,部署

  • elasticsearch 是如何实现 master 选举的

  • Elasticsearch 在部署时,对 Linux 的设置有哪些优化方法

  • 详细描述一下 Elasticsearch 更新和删除文档的过程。

  • Elasticsearch 在部署时,对 Linux 的设置有哪些优化方法?

...........

Redis 面试题

随着应用研发技术的不断成熟,Redis 缓存技术已经成为后台研发同学必备的能力之一。在很多公司面试的过程中,都必不可少地考察 Redis 知识点的掌握。

  • 使用 Redis 有哪些好处?

  • Redis 是单进程单线程的?

  • Redis 的持久化机制是什么?各自的优缺点?

  • Redis 常见异常问题和解决方案(雪崩,穿透...)

  • redis 过期键的删除策略?

  • 为什么 redis 需要把所有数据放到内存中?

  • Redis 集群的主从复制模型是怎样的?

  • Redis key 的过期时间和永久有效分别怎么设置?


MySQL 面试题

如今互联网行业用的最多就是 MySQL,然而对于高级 Web 面试者,尤其对于寻找 30k 下工作的求职者,很多 MySQL 相关知识点基本都会涉及,如果面试中,你的相关知识答的模糊和不切要点,基本大多稍好公司的面试官,基本也不会对你有兴趣,毕竟稍微量大的项目,最终都会让你去深入数据库,而且最终的大多瓶颈首先也会出现在数据库。

  • MySQL 相关存储引擎。

  • MySQL 索引实现原理。

  • MySQL 数据库锁。

  • MySQL 的 SQL 调优。

  • MySQL 分表分库全局 ID。

...............

Java 并发编程

  • 在 java 中守护线程和本地线程区别?

  • 什么是多线程中的上下文切换?

  • Java 中用到的线程调度算法是什么?

  • 什么是线程组,为什么在 Java 中不推荐使用?

  • 在 Java 中 Executor 和 Executors 的区别?

  • 并发编程三要素?

  • 什么是线程池?有哪几种创建方式?

.........

Spring 面试题

  • 1. 谈谈对 Spring IoC 的理解?

  • 2. 谈谈对 Spring DI 的理解?

  • 3. BeanFactory 接口和 ApplicationContext 接口不同点是什么?

  • 4. 请介绍你熟悉的 Spring 核心类,并说明有什么作用?

  • 5. 介绍一下 Spring 的事务的了解?

  • 6. 介绍一下 Spring 的事务实现方式?

  • 7.什么是 Spring 的依赖注入?

..........

Kafka 面试题

  • Kafka 与传统 MQ 消息系统之间有三个关键区别

  • 讲一讲 kafka 的 ack 的三种机制

  • 消费者故障,出现活锁问题如何解决?

  • kafka 分布式(不是单机)的情况下,如何保证消息的顺序消费

  • kafka 如何不消费重复数据?比如扣款,我们不能重复的扣。

....

读者福利

由于题量较多,篇幅的限制,文章中的面试题分享没有全部附上详细的解析,希望各位同仁理解但是整理成了一份详细的 PDF 文档可分享给大家

真诚分享,如果文章能够帮到您,那么我写这篇文章也就满足了,加 VX 小助理即可免费领取


用户头像

Geek_Yin

关注

还未添加个人签名 2022.08.19 加入

还未添加个人简介

评论

发布
暂无评论
2022年最新【Java经典面试800题】面试必备,查漏补缺;多线程+spring+JVM调优+分布式+redis+算法_编程_Geek_Yin_InfoQ写作社区