2020最常见的200+Java面试题汇总(含答案解析)

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
简介: 面试题内容包含: Java 基础、容器、多线程、反射、对象拷贝、Java Web 、异常、网络、设计模式、Spring/Spring MVC、Spring Boot/Spring Cloud、Hibernate、MyBatis、RabbitMQ、Kafka、Zookeeper、MySQL、Redis、JVM 。

前言

2020年快要结束了,很多朋友问题,有没有整理今年的一些面试题,最近抽时间整理了一份Java面试题。或许这份面试题还不足以囊括所有 Java 问题,但有了它,我相信足以应对目前市面上绝大部分的 Java 面试了,因为这篇文章不论是从深度还是广度上来讲,都已经囊括了非常多的知识点了。

这份面试题的包含的模块分为19个模块,分别是: Java 基础、容器、多线程、反射、对象拷贝、Java Web 、异常、网络、设计模式、Spring/Spring MVC、Spring Boot/Spring Cloud、Hibernate、MyBatis、RabbitMQ、Kafka、Zookeeper、MySQL、Redis、JVM 。如下图所示

本文主要就是为读者朋友们整理一份比较实用的面试清单,下面一起进入主题吧。

一、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的常用方法都有哪些?

i

二、容器系列面试题

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. 多线程中 synchronized 锁升级的原理是什么?

49. 什么是死锁?

50. 怎么防止死锁?

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

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

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

54. synchronized 和 Lock 有什么区别?

55. synchronized 和 ReentrantLock 区别是什么?

56. 说一下 atomic 的原理?

四、反射、对象拷贝、Java Web面试题

57. 什么是反射?

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

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

60. 怎么实现动态代理?

61. 为什么要使用克隆?

62. 如何实现对象克隆?

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

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、Spring Boot、Spring Cloud系列面试题

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 的作用是什么?

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、MyBatis系列面试题

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 实体类必须要有无参构造函数吗?为什么?

125. MyBatis 中 #{}和 的区别是什么?

126. MyBatis 有几种分页方式?

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

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

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

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

131. MyBatis 和 hibernate 的区别有哪些?

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

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

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

八、RabbitMQ、Kafka、Zookeeper系列面试题

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 对集群节点停止顺序有要求吗?

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

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

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

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

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

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 和 memcache 有什么区别?

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 运行时数据区?

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

196. 说一下堆栈的区别?

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

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

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

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

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

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

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

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

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

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

207. 说一下 JVM 调优的工具?

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

总结:

所有的面试题目都不是一成不变的,上面的面试题只是给大家一个借鉴作用,最主要的是给自己增加知识的储备,有备无患。关注公种浩:程序员追风,回复【009】获取资料。上面分享的2020最新200+Java面试题的答案都整理成了PDF文档。

相关文章
|
10天前
|
安全 架构师 Java
Java大厂面试高频:Collection 和 Collections 到底咋回答?
Java中的`Collection`和`Collections`是两个容易混淆的概念。`Collection`是集合框架的根接口,定义了集合的基本操作方法,如添加、删除等;而`Collections`是一个工具类,提供了操作集合的静态方法,如排序、查找、同步化等。简单来说,`Collection`关注数据结构,`Collections`则提供功能增强。通过小王的面试经历,我们可以更好地理解这两者的区别及其在实际开发中的应用。希望这篇文章能帮助你掌握这个经典面试题。
28 4
|
6天前
|
SQL Java 数据库连接
如何在 Java 代码中使用 JSqlParser 解析复杂的 SQL 语句?
大家好,我是 V 哥。JSqlParser 是一个用于解析 SQL 语句的 Java 库,可将 SQL 解析为 Java 对象树,支持多种 SQL 类型(如 `SELECT`、`INSERT` 等)。它适用于 SQL 分析、修改、生成和验证等场景。通过 Maven 或 Gradle 安装后,可以方便地在 Java 代码中使用。
94 11
|
5天前
|
存储 分布式计算 Hadoop
基于Java的Hadoop文件处理系统:高效分布式数据解析与存储
本文介绍了如何借鉴Hadoop的设计思想,使用Java实现其核心功能MapReduce,解决海量数据处理问题。通过类比图书馆管理系统,详细解释了Hadoop的两大组件:HDFS(分布式文件系统)和MapReduce(分布式计算模型)。具体实现了单词统计任务,并扩展支持CSV和JSON格式的数据解析。为了提升性能,引入了Combiner减少中间数据传输,以及自定义Partitioner解决数据倾斜问题。最后总结了Hadoop在大数据处理中的重要性,鼓励Java开发者学习Hadoop以拓展技术边界。
28 7
|
10天前
|
监控 Dubbo Java
Java Dubbo 面试题
Java Dubbo相关基础面试题
|
10天前
|
SQL Java 数据库连接
Java MyBatis 面试题
Java MyBatis相关基础面试题
|
10天前
|
存储 监控 算法
Java JVM 面试题
Java JVM(虚拟机)相关基础面试题
|
10天前
|
SQL 监控 druid
Java Druid 面试题
Java Druid 连接池相关基础面试题
|
10天前
|
缓存 安全 算法
Java 多线程 面试题
Java 多线程 相关基础面试题
|
SQL 缓存 安全
Java高频面试题目
面试时面试官最常问的问题总结归纳!
158 0
JAVA高频面试题目集锦(6)
JAVA高频面试题目集锦(6)
152 0
JAVA高频面试题目集锦(6)

热门文章

最新文章

推荐镜像

更多