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

# **JVM**
1. 说一下 jvm 的主要组成部分?及其作用?
2. 说一下 jvm 运行时数据区?
3. 说一下堆栈的区别?
4. 队列和栈是什么?有什么区别?
5. 什么是双亲委派模型?
6. 说一下类加载的执行过程?
7. 怎么判断对象是否可以被回收?
8. java 中都有哪些引用类型?
9. 说一下 jvm 有哪些
垃圾回收算法?
10. 说一下 jvm 有哪些
垃圾回收器?
11. 详细介绍一下 CMS
垃圾回收器?
12. 新生代
垃圾回收器和老生代
垃圾回收器都有哪些?有什么区别?
13. 简述分代
垃圾回收器是怎么工作的?
14. 说一下 jvm 调优的工具?
15. 常用的 jvm 调优的参数都有哪些?

# **Java多线程**
1. 并行和并发有什么区别?
2. 线程和进程的区别?
3. 守护线程是什么?
4. 创建线程有哪几种方式?
5. 说一下 runnable 和 callable 有什么区别?
6. 线程有哪些状态?
7. sleep() 和 wait() 有什么区别?
8. notify()和 notifyAll()有什么区别?
9. 线程的 run()和 start()有什么区别?
10. 44.创建线程池有哪几种方式?
11. 45.线程池都有哪些状态?
12. 线程池中 submit()和 execute()
方法有什么区别?
13. 在 java 程序中怎么保证多线程的运行安全?
14. 多线程锁的
升级原理是什么?
15. 什么是死锁?
16. 怎么防止死锁?
17. ThreadLocal 是什么?有哪些使用场景?
18. 说一下 synchronized 底层实现原理?
19. synchronized 和 volatile 的区别是什么?
20. synchronized 和 Lock 有什么区别?
21. synchronized 和
reentrantlock 区别是什么?
22. 说一下 atomic 的原理?

# **Spring/Spring MVC**
1. 为什么要使用 spring?
2. 解释一下什么是 aop?
3. 解释一下什么是 ioc?
4. spring 有哪些主要模块?
5. spring 常用的注入方式有哪些?
6. spring 中的 bean 是线程安全的吗?
7. spring
支持几种 bean 的作用域?
8. spring
自动装配 bean 有哪些方式?
9. spring 事务实现方式有哪些?
10. 说一下 spring 的事务隔离?
11. 说一下 spring mvc 运行流程?
12. spring mvc 有哪些组件?
13. @RequestMapping 的作用是什么?
14. @Autowired 的作用是什么?

# **Spring Boot/Spring Cloud**
1. 什么是 spring boot?
2. 为什么要用 spring boot?
3. spring boot 核心
配置文件是什么?
4. spring boot
配置文件有哪几种类型?它们有什么区别?
5. spring boot 有哪些方式可以实现热部署?
6. jpa 和 hibernate 有什么区别?
7. 什么是 spring cloud?
8. spring cloud 断路器的作用是什么?
9. spring cloud 的核心组件有哪些?

# **容器**
1. java 容器都有哪些?
2. Collection 和 Collections 有什么区别?
3. List、Set、Map 之
间的区别是什么?
4. HashMap 和 Hashtable 有什么区别?
5. 如何决定使用 HashMap 还是 TreeMap?
6. 说一下 HashMap 的实现原理?
7. 说一下 HashSet 的实现原理?
8. ArrayList 和 LinkedList 的区别是什么?
9. 如何实现数组和 List 之
间的转换?
10. ArrayList 和 Vector 的区别是什么?
11. Array 和 ArrayList 有何区别?
12. 在 Queue 中 poll()和 remove()有什么区别?
13. 哪些集合类是线程安全的?
14. 迭代器 I
terator 是什么?
15. I
terator 怎么使用?有什么特点?
16. I
terator 和 ListI
terator 有什么区别?
17. 怎么确保
一个集合不能被
修改?
# **Java反射**
1. 什么是反射?
2. 什么是 java 序列化?什么情况下需要序列化?
3. 动态代理是什么?有哪些应用?
4. 怎么实现动态代理?

# **异常**
1. throw 和 throws 的区别?
2. final、finally、finalize 有什么区别?
3. try-catch-finally 中哪个部分可以省略?
4. try-catch-finally 中,如果 catch 中 return 了,finally 还会执行吗?
5. 常见的异常类有哪些?
# **网络**
1. http 响应码 301 和 302 代表的是什么?有什么区别?
2. forward 和 redirect 的区别?
3. 简述 tcp 和 udp的区别?
4. tcp 为什么要三次握手,两次不行吗?为什么?
5. 说一下 tcp 粘包是怎么产生的?
6. OSI 的七层模型都有哪些?
7. get 和 post 请求有哪些区别?
8. 如何实现跨域?
9. 说一下 JSONP 实现原理?
# **设计模式**
1. 说一下你熟悉的设计模式?
2. 简单工厂和抽象工厂有什么区别?
3. 请列举出在 JDK 中几个常用的设计模式?
4. 在 Java 中,什么叫观察者设计模式(observer design pattern)?
5. .使用工厂模式最主要的好处是什么?在哪里使用?
# **Re
dis**
1. re
dis 是什么?都有哪些使用场景?
2. re
dis 有哪些
功能?
3. re
dis 和 memecache 有什么区别?
4. re
dis 为什么是单线程的?
5. 什么是缓存穿透?怎么
解决?
6. re
dis 支持的数据类型有哪些?
7. re
dis 支持的 java 客户端都有哪些?
8. je
dis 和 re
disson 有哪些区别?
9. 怎么保证缓存和
数据库数据的一致性?
10. re
dis 持久化有几种方式?
11. 189.re
dis 怎么实现分布式锁?
12. re
dis 分布式锁有什么缺陷?
13. re
dis 如何做内存优化?
14. re
dis 淘汰策略有哪些?
15. re
dis 常见的
性能问题有哪些?该如何
解决?

# **
MysqL**
1.
数据库的三范式是什么?
2. 一张自增表里面总共有 7 条数据,
删除了最后 2 条数据,重启
MysqL 数据库,又插入了一条数据,此时 id 是几?
3. 如何
获取当前
数据库版本?
4. 说一下 ACID 是什么?
5. char 和 varchar 的区别是什么?
6. float 和 double 的区别是什么?
7.
MysqL 的内连接、左连接、右连接有什么区别?
8.
MysqL 索引是怎么实现的?
9. 怎么验证
MysqL 的索引是否满足需求?
10. 说一下
数据库的事务隔离?
11. 说一下
MysqL 常用的引擎?
12. 说一下
MysqL 的行锁和表锁?
13. 说一下乐观锁和悲观锁?
14.
MysqL 问题排查都有哪些手段?
15. 如何做
MysqL 的
性能优化?

# **Hibernate**
1. 为什么要使用 hibernate?
2. 什么是 ORM 框架?
3. hibernate 中如何在控制台查看打印的
sql 语句?
4. hibernate 有几种
查询方式?
5. hibernate
实体类可以被定义为 final 吗?
6. 在 hibernate 中使用 Integer 和 int 做映射有什么区别?
7. hibernate 是如何工作的?
8. get()和 load()的区别?
9. 说一下 hibernate 的缓存机制?
10. hibernate 对象有哪些状态?
11. 在 hibernate 中 getCurrentSession 和 openSession 的区别是什么?
12. hibernate
实体类必须要有无参构造
函数吗?为什么?
# **Mybatis**
1. mybatis 中 #{}和 ${}的区别是什么?
2. mybatis 有几种
分页方式?
3. RowBounds 是一次性
查询全部结果吗?为什么?
4. mybatis 逻辑
分页和物理
分页的区别是什么?
5. mybatis 是否
支持延迟加载?延迟加载的原理是什么?
6. 说一下 mybatis 的一级缓存和二级缓存?
7. mybatis 和 hibernate 的区别有哪些?
8. mybatis 有哪些执行器(Executor)?
9. mybatis
分页插件的实现原理是什么?
10. mybatis 如何编写
一个自定义插件?

# **RabbitMQ**
1. rabbitmq 的使用场景有哪些?
2. rabbitmq 有哪些重要的角色?
3. rabbitmq 有哪些重要的组件?
4. rabbitmq 中 vhost 的作用是什么?
5. rabbitmq 的消息是怎么发送的?
6. rabbitmq 怎么保证消息的稳定性?
7. 141.rabbitmq 怎么避免消息丢失?
8. 要保证消息持久化成功的条件有哪些?
9. rabbitmq 持久化有什么缺点?
10. rabbitmq 有几种广播类型?
11. rabbitmq 怎么实现延迟消息队列?
12. rabbitmq 集群有什么用?
13. rabbitmq 节点的类型有哪些?
14. rabbitmq 集群搭建需要注意哪些问题?
15. rabbitmq 每个节点是其他节点的完整拷贝吗?为什么?
16. rabbitmq 集群中唯一
一个磁盘节点崩溃了会发生什么情况?
17. rabbitmq 对集群节点停止顺序有要求吗?

# **Kafka**
1. kafka 可以脱离 zookeeper 单独使用吗?为什么?
2. kafka 有几种数据保留的策略?
3. kafka 同时设置了 7 天河 10G 清除数据,到第五天的时候消息达到了 10G,这个时候 kafka 将如何处理?
4. 什么情况会导致 kafka 运行变慢?
5. 使用 kafka 集群需要注意什么?

# **Zookeeper**
1. zookeeper 是什么?
2. zookeeper 都有哪些
功能?
3. zookeeper 有几种部署模式?
4. zookeeper 怎么保证主从节点的状态同步?
5. 集群中为什么要有主节点?
6. 集群中有 3 台服务器,其中
一个节点宕机,这个时候 zookeeper 还可以使用吗?
7. 说一下 zookeeper 的
通知机制?

#
## 总结:绘上一张Kakfa架构思维大纲脑图(xmind)

其实关于Kafka,能问的问题实在是太多了,扒了几天,最终筛选出44问:基础篇17问、进阶篇15问、高级篇12问,个个直戳痛点,不知道如果你不着急看答案,又能答出几个呢?
若是对Kafka的知识还回忆不起来,不妨先看我手绘的知识总结脑图(xmind不能
上传,
文章里用的是
图片版)进行整体架构的梳理
**[资料领取方式:点击这里
免费下载](https://docs.qq.com/doc/DSmxTbFJ1cmN1R2dB)**
梳理了知识,刷完了面试,如若你还想进一步的深入学习解读kafka以及源码,那么接下来的这份《手写“kafka”》将会是个不错的选择。
* Kafka入门
* 为什么选择Kafka
* Kafka的安装、管理和配置
* Kafka的集群
* 第
一个Kafka程序
* Kafka的生产者
* Kafka的消费者
* 深入理解Kafka
* 可靠的数据传递
* Spring和Kafka的整合
* SpringBoot和Kafka的整合
* Kafka实战之削峰填谷
* 数据管道和流式处理(了解即可)


版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。