一起看看这些大厂面试真题查漏补缺吧,Java面试题总结(附答案

3、Java 中什么叫单例设计模式?请用 Java 写出线程安全的单例模式

4、在 Java 中,什么叫观察者设计模式(observer design pattern)?

5、使用工厂模式最主要的好处是什么?在哪里使用?

6、举一个用 Java 实现的装饰模式(decorator design pattern)?它是作用于对象层次还是类层次?

7、在 Java 中,为什么不允许从静态方法中访问非静态变量?

8、设计一个 ATM 机,请说出你的设计思路?

9、在 Java 中,什么时候用重载,什么时候用重写?

10、举例说明什么情况下会更倾向于使用抽象类而不是接口

七、Spring/SpringMVC


1、什么是 Spring 框架?Spring 框架有哪些主要模块?

2、使用 Spring 框架能带来哪些好处?

3、什么是控制反转(IOC)?什么是依赖注入?

4、请解释下 Spring 框架中的 IoC?

5、BeanFactory 和 ApplicationContext 有什么区别?

6、Spring 有几种配置方式?

7、请解释 Spring Bean 的生命周期?

8、Spring Bean 的作用域之间有什么区别?

9、什么是 Spring inner beans?

10、Spring 框架中的单例 Beans 是线程安全的么?

11、请举例说明如何在 Spring 中注入一个 Java Collection?

12、如何向 Spring Bean 中注入一个 Java.util.Properties?

13、请解释 Spring Bean 的自动装配?

14、请解释自动装配模式的区别?

15、如何开启基于注解的自动装配?

16、请举例解释@Required 注解?

17、请举例解释@Autowired 注解?

18、请举例说明@Qualifier 注解?

19、构造方法注入和设值注入有什么区别?

20、Spring 框架中有哪些不同类型的事件?

21、FileSystemResource 和 ClassPathResource 有何区别?

22、Spring 框架中都用到了哪些设计模式?

八、Spring Boot/Spring Cloud


1、什么是 Spring Boot?

2、Spring Boot 有哪些优点?

3、什么是 JavaConfig?

5、Spring Boot 中的监视器是什么?

6、如何在 Spring Boot 中禁用 Actuator 端点安全性?

7、如何在自定义端口上运行 Spring Boot 应用程序?

8、什么是 YAML?

9、如何实现 Spring Boot 应用程序的安全性?

10、如何集成 Spring Boot 和 ActiveMQ?

11、如何使用 Spring Boot 实现分页和排序?

12、什么是 Swagger?你用 Spring Boot 实现了它吗?

13、什么是 Spring Profiles?

14、什么是 Spring Batch?

15、什么是 FreeMarker 模板?

16、如何使用 Spring Boot 实现异常处理?

17、您使用了哪些 starter maven 依赖项?

18、什么是 CSRF 攻击?

19、什么是 WebSockets?

20、什么是 AOP?

21、什么是 Apache Kafka?

22、我们如何监视所有 Spring Boot 微服务?

23、什么是 spring cloud?

24、spring cloud 断路器的作用是什么?

26、spring cloud 的核心组件有哪些?

九、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、RabbitMQ怎么避免消息丢失?

8、要保证消息持久化成功的条件有哪些?

9、RabbitMQ持久化有什么缺点?

10、RabbitMQ有几种广播类型?

11、RabbitMQ怎么实现延迟消息队列?

12、RabbitMQ集群有什么用?

13、RabbitMQ节点的类型有哪些?

14、RabbitMQ集群搭建需要注意哪些问题?

15、RabbitMQ每个节点是其他节点的完整拷贝吗?为什么?

16、RabbitMQ集群中唯一一个磁盘节点崩溃了会发生什么情况?

17、RabbitMQ对集群节点停止顺序有要求吗?

十二 、Kafka(未掌握,暂时不做)


  1. 如何获取 topic 主题的列表

  2. 生产者和消费者的命令行是什么?

  3. consumer是推还是拉?

  4. 讲讲kafka维护消费状态跟踪的方法

  5. 讲一下主从同步

  6. 为什么需要消息系统,mysql 不能满足需求吗?

  7. Zookeeper 对于 Kafka 的作用是什么?

  8. 数据传输的事务定义有哪三种?

  9. Kafka 判断一个节点是否还活着有那两个条件?

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

  11. 讲一讲 kafka 的 ack 的三种机制

  12. 消费者如何不自动提交偏移量,由应用提交?

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

  14. 如何控制消费的位置

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

  16. kafka的高可用机制是什么?

  17. kafka如何减少数据丢失

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

十三、Zookeeper(未掌握,暂时不做)


  1. ZooKeeper 提供了什么?

  2. Zookeeper 文件系统

  3. ZAB 协议?

  4. 四种类型的数据节点 Znode

  5. Zookeeper Watcher 机制 – 数据变更通知

  6. 客户端注册 Watcher 实现

  7. 服务端处理 Watcher 实现

  8. 客户端回调 Watcher

  9. ACL 权限控制机制

  10. Chroot 特性

  11. 会话管理

  12. 服务器角色

  13. Zookeeper 下 Server 工作状态

  14. 数据同步

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

  16. 分布式集群中为什么会有 Master?

  17. zk 节点宕机如何处理?

  18. zookeeper 负载均衡和 nginx 负载均衡区别

  19. Zookeeper 有哪几种几种部署模式?

  20. 集群最少要几台机器,集群规则是怎样的?

  21. 集群支持动态添加机器吗?

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

  23. Zookeeper 的 java 客户端都有哪些?

  24. chubby 是什么,和 zookeeper 比你怎么看?

  25. 说几个 zookeeper 常用的命令。

  26. ZAB 和 Paxos 算法的联系与区别?

  27. Zookeeper 的典型应用场景

十四、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 的性能优化?

十五、Redis


1、Redis是什么?都有哪些使用场景?

2、Redis有哪些功能?

3、Redis和 memecache 有什么区别?

4、Redis为什么是单线程的?

5、什么是缓存穿透?怎么解决?

6、Redis支持的数据类型有哪些?

7、Redis支持的 java 客户端都有哪些?

8、jedis 和 redisson 有哪些区别?

9、怎么保证缓存和数据库数据的一致性?

10、Redis持久化有几种方式?

11、Redis怎么实现分布式锁?

12、Redis分布式锁有什么缺陷?

13、Redis如何做内存优化?

14、Redis淘汰策略有哪些?

15、Redis常见的性能问题有哪些?该如何解决?

十六、JVM


1、说一下 jvm 的主要组成部分?及其作用?

2、说一下 jvm 运行时数据区?

3、说一下堆栈的区别?

4、什么是类加载器,类加载器有哪些?

5、什么是双亲委派模型?

6、说一下类加载的执行过程?

7、怎么判断对象是否可以被回收?

8、java 中都有哪些引用类型?

9、说一下 jvm 有哪些垃圾回收算法?

10、说一下 jvm 有哪些垃圾回收器?

11、详细介绍一下 CMS 垃圾回收器?

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

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

14、说一下 jvm 调优的工具?

15、常用的 jvm 调优的参数都有哪些?

16、Java 类加载过程?

17、描述一下 JVM 加载 Class 文件的原理机制?

18、Java 内存分配。

19、GC 是什么? 为什么要有 GC?

20、简述 Java 垃圾回收机制

21、如何判断一个对象是否存活?(或者 GC 对象的判定方法)

22、垃圾回收的优点和原理。并考虑 2 种回收机制

23、垃圾回收器的基本原理是什么?垃圾回收器可以马上回收内存吗?有什么办法主动通知虚拟机进行垃圾回收?

24、Java 中会存在内存泄漏吗,请简单描述

25、深拷贝和浅拷贝。

26、System.gc() 和 Runtime.gc() 会做什么事情?

27、finalize() 方法什么时候被调用?析构函数 (finalization) 的目的是什么?

28、如果对象的引用被置为 null,垃圾收集器是否会立即释放对象占用的内存?

29、串行(serial)收集器和吞吐量(throughput)收集器的区别是什么?

30、在 Java 中,对象什么时候可以被垃圾回收?

31、简述 Java 内存分配与回收策略以及 Minor GC 和 Major GC。

32、VM 的永久代中会发生垃圾回收么?

33、Java 中垃圾收集的方法有哪些?

十七、Dubbo 面试题(未掌握,暂时不做)


  1. 为什么要用 Dubbo?

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

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

  4. 服务调用是阻塞的吗?

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

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

  7. 服务提供者能实现失效踢出是什么原理?

  8. 服务上线怎么不影响旧版本?

  9. 如何解决服务调用链过长的问题?

  10. 说说核心的配置有哪些?

  11. Dubbo 推荐用什么协议?

  12. 同一个服务多个注册的情况下可以直连某一个服务吗?

  13. 画一画服务注册与发现的流程图?

  14. Dubbo 集群容错有几种方案?

  15. Dubbo 服务降级,失败重试怎么做?

  16. Dubbo 使用过程中都遇到了些什么问题?

  17. Dubbo Monitor 实现原理?

  18. Dubbo 用到哪些设计模式?

  19. Dubbo 配置文件是如何加载到 Spring 中的?

  20. Dubbo SPI 和 Java SPI 区别?

  21. Dubbo 支持分布式事务吗?

  22. Dubbo 可以对结果进行缓存吗?

  23. 服务上线怎么兼容旧版本?

  24. Dubbo 必须依赖的包有哪些?

  25. Dubbo telnet 命令能做什么?

  26. Dubbo 支持服务降级吗?

  27. Dubbo 如何优雅停机?

  28. Dubbo 和 Dubbox 之间的区别?

  29. Dubbo 和 Spring Cloud 的区别?

  30. 你还了解别的分布式框架吗?

十八、Elasticsearch 面试题(未掌握,暂时不做)


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

  2. elasticsearch 的倒排索引是什么

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

  4. elasticsearch 是如何实现 master 选举的

  5. 详细描述一下 Elasticsearch 索引文档的过程

  6. 详细描述一下 Elasticsearch 搜索的过程?

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

  8. lucence 内部结构是什么?

  9. Elasticsearch 是如何实现 Master 选举的?

  10. Elasticsearch 中的节点(比如共 20 个),其中的 10 个选了一个 master,另外 10 个选了另一个 master,怎么办?

  11. 客户端在和集群连接时,如何选择特定的节点执行请求的?

  12. 详细描述一下 Elasticsearch 索引文档的过程。

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

  14. 详细描述一下 Elasticsearch 搜索的过程

  15. 在 Elasticsearch 中,是怎么根据一个词找到对应的倒排索引的?

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

  17. 对于 GC 方面,在使用 Elasticsearch 时要注意什么?

  18. Elasticsearch 对于大数据量(上亿量级)的聚合如何实现?

  19. 在并发情况下,Elasticsearch 如果保证读写一致?

  20. 如何监控 Elasticsearch 集群状态?

  21. 介绍下你们电商搜索的整体技术架构

  22. 介绍一下你们的个性化搜索方案?

  23. 是否了解字典树?

  24. 拼写纠错是如何实现的?

最后

如何获取免费架构学习资料?

资料获取方式:点击下方蓝色传送门

Java学习、面试;文档、视频资源免费获取

由于篇幅原因,就不多做展示了
,在使用 Elasticsearch 时要注意什么?

  1. Elasticsearch 对于大数据量(上亿量级)的聚合如何实现?

  2. 在并发情况下,Elasticsearch 如果保证读写一致?

  3. 如何监控 Elasticsearch 集群状态?

  4. 介绍下你们电商搜索的整体技术架构

  5. 介绍一下你们的个性化搜索方案?

  6. 是否了解字典树?

  7. 拼写纠错是如何实现的?

最后

如何获取免费架构学习资料?

资料获取方式:点击下方蓝色传送门

Java学习、面试;文档、视频资源免费获取

[外链图片转存中…(img-CaD4yWfO-1628313926410)]

[外链图片转存中…(img-SgvRLBs9-1628313926411)]

[外链图片转存中…(img-TLkSyqSk-1628313926412)]

[外链图片转存中…(img-eBLu2t1S-1628313926414)]

[外链图片转存中…(img-Fr0x2QH8-1628313926415)]

[外链图片转存中…(img-vWCp3g0A-1628313926416)]

由于篇幅原因,就不多做展示了

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值