写点什么

这才是打开 Java 面试的正确方式,金三银四互联网大厂 Java 面试八股来袭

作者:架构师之道
  • 2023-02-17
    湖南
  • 本文字数:5361 字

    阅读完需:约 18 分钟

前言

春节过后招聘旺季就到了,不知道大家是否准备好了,面对金三银四的招聘旺季,如果没有精心准备那笔者认为那是对自己不负责任;就我们 Java 程序员来说,多数的公司总体上面试都是以自我介绍+项目介绍+项目细节/难点提问+基础知识点考核+算法题这个流程下来的。

有些公司可能还会问几个实际的场景类的问题,这个环节阿里是必问的,这种问题通常是没有正确答案的,就看个人的理解,个人的积累了。剩下的就没啥了,都是换汤不换药,聊项目就看你自己对你自己的项目是否理解的透彻,比如经常问你你为什么选择这个技术,为什么这么处理之类的,常考的基础的知识点就那么多,最后算法就是靠刷题。

今天为大家分享的就是当前互联网企业使用频率最高的面试题库,经过精心整理后,所有问题都已更新出详细的答案解析,比较难以理解的还专门做了技术文档以便于大家阅读学习。

本次分享总共涉及知识点:Java 基础、多线程、JVM、Spring、SpringMVC、SpringCloud、Spring Boot、高并发、Redis、kafka、消息中间件 MQ、Dubbo、Tomcat、网络协议、数据结构、MySQL、MyBatis、设计模式、算法等。

由于资料内容太多,平台篇幅限制,小编就展现了以上部分面试专题与资料,如需获取以下全部面试资料可以添加上小助手 vx:bjmsb15 获取

一、多线程面试专题


  1. 现在有 T1、T2、T3 三个线程,你怎样保证 T2 在 T1 执行完后执行,T3 在 T2 执行完后执行?

  2. 在 Java 中 Lock 接口比 synchronized 块的优势是什么?你需要实现一个高效的缓存,它允许多个用户读,但只允许一个用户写,以此来保持它的完整性,你会怎样去实现它?

  3. 在 java 中 wait 和 sleep 方法的不同?

  4. 用 Java 实现阻塞队列。

  5. 用 Java 写代码来解决生产者——消费者问题。

  6. 用 Java 编程一个会导致死锁的程序,你将怎么解决?

  7. 什么是原子操作,Java 中的原子操作是什么?

  8. Java 中的 volatile 关键是什么作用?怎样使用它?在 Java 中它跟 synchronized 方法有什么不同?

  9. 什么是竞争条件?你怎样发现和解决竞争?

  10. 你将如何使用 threaddump?你将如何分析 Thread dump?

  11. 为什么我们调用 start()方法时会执行 run()方法,为什么我们不能直接调用 run()方法?

  12. Java 中 你怎样唤醒一个阻塞的线程?

  13. 在 Java 中 CycliBarriar 和 CountdownLatch 有什么区别?

  14. 什么是不可变对象,它对写并发应用有什么帮助?

  15. 你在多线程环境中遇到的常见的问题是什么?你是怎么解决它的?



多线程面试专题答案解析文档截图


二、JVM 面试专题


  1. 内存模型以及分区,需要详细到每个区放什么。

  2. 堆里面的分区:Eden,survival (from+ to),老年代,各自的特点。

  3. 对象创建方法,对象的内存分配,对象的访问定位。

  4. GC 的两种判定方法:

  5. SafePoint 是什么

  6. GC 的三种收集方法:标记清除、标记整理、复制算法的原理与特点,分别用在什么地方,如果让你优化收集方法,有什么思路?

  7. GC 收集器有哪些?CMS 收集器与 G1 收集器的特点。

  8. Minor GC 与 Full GC 分别在什么时候发生?

  9. 几种常用的内存调试工具:jmap、jstack、jconsole、jhat

  10. 类加载的几个过程:

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

  12. 简述 java 垃圾回收机制?

  13. java 内存模型

  14. 简述 java 类加载机制?

  15. 类加载器双亲委派模型机制?

  16. 什么是类加载器,类加载器有哪些?

  17. 简述 java 内存分配与回收策略以及 Minor GC 和 Major GC



JVM 面试专题答案解析文档截图


三、Spring 面试专题


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

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

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

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

  5. BeanFactory 和 ApplicationContext 有什么区别?

  6. Spring 有几种配置方式?

  7. 如何用基于 XML 配置的方式配置 Spring?

  8. 如何用基于 Java 配置的方式配置 Spring?

  9. 怎样用注解的方式配置 Spring?

  10. 请解释 Spring Bean 的生命周期?

  11. Spring Bean 的作用域之间有什么区别?

  12. 什么是 Spring inner beans?

  13. Spring 框架中的单例 Beans 是线程安全的么?

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

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

  16. 请解释 Spring Bean 的自动装配?

  17. 请解释自动装配模式的区别?

  18. 如何开启基于注解的自动装配?

  19. 请举例解释 @Required 注解?

  20. 请举例解释 @Autowired 注解?

  21. 请举例说明 @Qualifier 注解?

  22. 构造方法注入和设置注入有什么区别?

  23. Spring 框架中有哪些不同类型的事件?

  24. FileSystemResource 和 ClassPathResource 有何区别?

  25. Spring 框架中都用到了哪些设计模式?



Spring 面试专题答案解析文档截图


四、Spring Cloud、Spring Boot、SpringMVC 面试专题


1)Spring Cloud 面试专题


  1. 什么是 Spring Cloud?

  2. 使用 Spring Cloud 有什么优势?

  3. 服务注册和发现是什么意思?Spring Cloud 如何实现?

  4. 负载平衡的意义什么?

  5. 什么是 Hystrix?它如何实现容错?

  6. 什么是 Hystrix 断路器?我们需要它吗?

  7. 什么是 Netflix Feign?它的优点是什么?

  8. 什么是 Spring Cloud Bus?我们需要它吗?


2)Spring Boot 面试专题


  1. 什么是 Spring Boot?

  2. Spring Boot 有哪些优点?

  3. 什么是 JavaConfig?

  4. 如何重新加载 Spring Boot 上的更改,而无需重新启动服务器?

  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 微服务?



Spring Boot 面试专题答案解析文档截图


3)Spring MVC 面试专题


  1. 什么是 SpringMvc?

  2. Spring MVC 的优点:

  3. SpringMVC 工作原理?

  4. SpringMVC 流程?

  5. SpringMvc 的控制器是不是单例模式,如果是,有什么问题,怎么解决?

  6. 如果你也用过 struts2.简单介绍下 springMVC 和 struts2 的区别有哪些?

  7. SpingMvc 中的控制器的注解一般用哪个,有没有别的注解可以替代?

  8. @RequestMapping 注解用在类上面有什么作用?

  9. 怎么样把某个请求映射到特定的方法上面?

  10. 如果在拦截请求中,我想拦截 get 方式提交的方法,怎么配置?

  11. 怎么样在方法里面得到 Request,或者 Session?

  12. 我想在拦截的方法里面得到从前台传入的参数,怎么得到?

  13. 如果前台有很多个参数传入,并且这些参数都是一个对象的,那么怎么样快速得到这个对象?

  14. SpringMvc 中函数的返回值是什么?

  15. SpringMVC 怎么样设定重定向和转发的?

  16. SpringMvc 用什么对象从后台向前台传递数据的?

  17. SpringMvc 中有个类把视图和数据都合并的一起的,叫什么?

  18. 怎么样把 ModelMap 里面的数据放入 Session 里面?

  19. SpringMvc 怎么和 AJAX 相互调用的?

  20. 当一个方法向 AJAX 返回特殊对象,比如 Object,List 等,需要做什么处理?

  21. SpringMvc 里面拦截器是怎么写的

  22. 讲下 SpringMvc 的执行流程



五、Redis 面试专题 50 问


  1. 什么是 Redis?

  2. Redis 相比 memcached 有哪些优势?

  3. Redis 支持哪几种数据类型?

  4. Redis 主要消耗什么物理资源?

  5. Redis 的全称是什么?

  6. Redis 有哪几种数据淘汰策略?

  7. Redis 官方为什么不提供 Windows 版本?

  8. 一个字符串类型的 值 能 存储最大容量是多少?

  9. 为什么 Redis 需要把所有数据放到内存中?

  10. Redis 集群方案应该怎么做?都有哪些方案?

  11. Redis 集群方案什么情况下会导致整个集群不可用?

  12. MySQL 里有 2000w 数据,Redis 中只存 20w 的数据,如何保证 Redis 中的数据都是热点数据?

  13. Redis 有哪些适合的场景?

  14. Redis 支持的 Java 客户端都有哪些?官方推荐用哪个?

  15. Redis 和 Redisson 有什么关系?

  16. Jedis 与 Redisson 对比有什么优缺点?

  17. Redis 如何设置密码及验证密码?

  18. 说说 Redis 哈希槽的概念?

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

  20. Redis 集群会 有 写 操作丢失吗?为什么?

  21. Redis 集群之间是如何复制的?

  22. Redis 集群最大节点个数是多少?

  23. Redis 集群如何选择数据库?

  24. 怎么测试 Redis 的连通性?

  25. Redis 中的管道有什么用?

  26. 怎么理解 Redis 事务?

  27. Redis 事务相关的命令有哪几个?

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

  29. Redis 如何做内存优化?

  30. Redis 回收进程如何工作的?

  31. Redis 回收使用的是什么算法?

  32. Redis 如何做大量数据插入?

  33. 为什么要做 Redis 分区?

  34. 你知道有哪些 Redis 分区实现方案?

  35. Redis 分区有什么缺点?

  36. Redis 持久化数据和缓存怎么做扩容?

  37. 分布式 Redis 是前期做还是后期规模上来了再做好?为什么?

  38. Twemproxy 是什么?

  39. 支持一致性哈希的客户端有哪些?

  40. Redis 与其他 key-value 存储有什么不同?

  41. Redis 的内存占用情况怎么样?

  42. 都有哪些办法可以降低 Redis 的内存使用情况呢?

  43. 查看 Redis 使用情况及状态信息用什么命令?

  44. Redis 的内存用完了会发生什么?

  45. Redis 是单线程的,如何提高多核 CPU 的利用率?

  46. 一个 Redis 实例最多能存放多少的 keys?List、Set、Sorted Set 他们最多能存放多少元素?

  47. Redis 常见性能问题和解决方案?

  48. Redis 提供了哪几种持久化方式?

  49. 如何选择合适的持久化方式?

  50. 修改配置不重启 Redis 会实时生效吗?



Redis 面试专题答案解析文档截图


六、RabbitMQ 面试专题


  1. RabbitMQ 中的 broker 是指什么?cluster 又是指什么?

  2. 什么是元数据?元数据分为哪些类型?包括哪些内容?与 cluster 相关的元数据有哪些?元数据是如何保存的?元数据在 cluster 中是如何分布的?

  3. RAM node 和 disk node 的区别?

  4. RabbitMQ 上的一个 queue 中存放的 message 是否有数量限制?

  5. RabbitMQ 概念里的 channel、exchange 和 queue 这些东东是逻辑概念,还是对应着进程实体?这些东东分别起什么作用?

  6. vhost 是什么?起什么作用?

  7. 在单 node 系统和多 node 构成的 cluster 系统中声明 queue、exchange ,以及进行 binding 会有什么不同?

  8. 客户端连接到 cluster 中的任意 node 上是否都能正常工作?

  9. 若 cluster 中拥有某个 queue 的 owner node 失效了,且该 queue 被声明具有 durable 属性,是否能够成功从其他 node 上重新声明该 queue ?

  10. cluster 中 node 的失效会对 consumer 产生什么影响?若是在 cluster 中创建了 mirrored queue ,这时 node 失效会对 consumer 产生什么影响?

  11. 能够在地理上分开的不同数据中心使用 RabbitMQ cluster 么?

  12. 为什么 heavy RPC 的使用场景下不建议采用 disk node ?

  13. 向不存在的 exchange 发 publish 消息会发生什么?向不存在的 queue 执行 consume 动作会发生什么?

  14. routing_key 和 binding_key 的最大长度是多少?

  15. RabbitMQ 允许发送的 message 最大可达多大?

  16. 什么情况下 producer 不主动创建 queue 是安全的?

  17. “dead letter”queue 的用途?

  18. 为什么说保证 message 被可靠持久化的条件是 queue 和 exchange 具有 durable 属性,同时 message 具有 persistent 属性才行?

  19. 什么情况下会出现 blackholed 问题?

  20. 如何防止出现 blackholed 问题?

  21. Consumer Cancellation Notification 机制用于什么场景?

  22. Basic.Reject 的用法是什么?

  23. 为什么不应该对所有的 message 都使用持久化机制?

  24. RabbitMQ 中的 cluster、mirrored queue,以及 warrens 机制分别用于解决什么问题?存在哪些问题?



RabbitMQ 面试专题答案解析文档截图


七、Nginx、Netty 面试专题


1)Nginx 面试专题


  1. 解释一下什么是 Nginx?

  2. 请列举 Nginx 的一些特性。

  3. 请列举 Nginx 和 Apache 之间的不同点

  4. 请解释 Nginx 如何处理 HTTP 请求。

  5. 在 Nginx 中,如何使用未定义的服务器名称来阻止处理请求?

  6. 使用“反向代理服务器”的优点是什么?

  7. 请列举 Nginx 服务器的最佳用途。

  8. 请解释 Nginx 服务器上的 Master 和 Worker 进程分别是什么?

  9. 请解释你如何通过不同于 80 的端口开启 Nginx?

  10. 解释是否有可能将 Nginx 的错误替换为 502 错误、503?

  11. 在 Nginx 中,解释如何在 URL 中保留双斜线?

  12. 请解释 ngx_http_upstream_module 的作用是什么?

  13. 请解释什么是 C10K 问题?

  14. 请陈述 stub_status 和 sub_filter 指令的作用是什么?

  15. 解释 Nginx 是否支持将请求压缩到上游?

  16. 解释如何在 Nginx 中 获得当前的时间?

  17. 用 Nginx 服务器解释-s 的目的是什么?

  18. 解释如何在 Nginx 服务器上添加模块?



2)Netty 面试专题


  1. BIO、NIO 和 AIO 的区别?

  2. NIO 的组成?

  3. Netty 的特点?

  4. Netty 的线程模型?

  5. TCP 粘包/拆包的原因及解决方法?

  6. 了解哪几种序列化协议?

  7. 如何选择序列化协议?

  8. Netty 的零拷贝实现?

  9. Netty 的高性能表现在哪些方面?

  10. NIOEventLoopGroup 源码?


八、数据结构面试专题


  1. ConcurrentHashMap 为何读不加锁。

  2. HashMap 如何同步。

  3. 说说常见的集合有哪些吧。

  4. HashMap 与 HashTable 的区别。

  5. HashMap 的 put 方法的具体流程。

  6. HashMap 的扩容操作是怎么实现的。

  7. HashMap 是怎么解决哈希冲突的。

  8. HashMap 为什么不直接使用 hashCode()处理后的哈希值之直接作为 table 的下标。

  9. 为什么 HashMap 中 String、Integer 这样的包装类适合作为 Key。

  10. ConcurrentHashMap 和 HashMap 的区别。

  11. Java 集合的快速失败机制“fail-fast”,以及安全失败“fail-safe”。

  12. ArrayList 和 CopyOnWriteArrayList 的区别。

  13. ArrayList 和 LinkedList 的区别。

  14. HashSet 是如何保证数据不可重复的。

  15. BlockingQueue 是什么。

  16. HashMap 为什么选用红黑树。

  17. Iterator 中是否存在 Add 方法。


由于资料内容太多,平台篇幅限制,小编就展现了以上部分面试专题与资料,如需获取以下全部面试资料可以添加上小助手 vx:bjmsb15 获取



用户头像

还未添加个人签名 2022-04-10 加入

还未添加个人简介

评论

发布
暂无评论
这才是打开Java面试的正确方式,金三银四互联网大厂Java面试八股来袭_编程_架构师之道_InfoQ写作社区