金三银四过后招聘旺季就到了,不知道大家是否准备好了,面对金九银十的招聘旺季,如果没有精心准备那笔者认为那是对自己不负责任;就我们 Java 程序员来说,多数的公司总体上面试都是以自我介绍+项目介绍+项目细节/难点提问+基础知识点考核+算法题这个流程下来的。
有些公司可能还会问几个实际的场景类的问题,这个环节阿里是必问的,这种问题通常是没有正确答案的,就看个人的理解,个人的积累了。剩下的就没啥了,都是换汤不换药,聊项目就看你自己对你自己的项目是否理解的透彻,比如经常问你你为什么选择这个技术,为什么这么处理之类的,常考的基础的知识点就那么多,最后算法就是靠刷题。
今天为大家分享的就是当前互联网企业使用频率最高的面试题库,经过精心整理后,所有问题都已更新出详细的答案解析,比较难以理解的还专门做了技术文档以便于大家阅读学习。
本次分享总共涉及知识点:Java 基础、多线程、JVM、Spring、SpringMVC、SpringCloud、Spring Boot、高并发、Redis、kafka、消息中间件 MQ、Dubbo、Tomcat、网络协议、数据结构、MySQL、MyBatis、设计模式、算法等。
一、多线程面试专题
- 现在有 T1、T2、T3 三个线程,你怎样保证 T2 在 T1 执行完后执行,T3 在 T2 执行完后执行?
- 在 Java 中 Lock 接口比 synchronized 块的优势是什么?你需要实现一个高效的缓存,它允许多个用户读,但只允许一个用户写,以此来保持它的完整性,你会怎样去实现它?
- 在 java 中 wait 和 sleep 方法的不同?
- 用 Java 实现阻塞队列。
- 用 Java 写代码来解决生产者——消费者问题。
- 用 Java 编程一个会导致死锁的程序,你将怎么解决?
- 什么是原子操作,Java 中的原子操作是什么?
- Java 中的 volatile 关键是什么作用?怎样使用它?在 Java 中它跟 synchronized 方法有什么不同?
- 什么是竞争条件?你怎样发现和解决竞争?
- 你将如何使用 threaddump?你将如何分析 Thread dump?
- 为什么我们调用 start()方法时会执行 run()方法,为什么我们不能直接调用 run()方法?
- Java 中 你怎样唤醒一个阻塞的线程?
- 在 Java 中 CycliBarriar 和 CountdownLatch 有什么区别?
- 什么是不可变对象,它对写并发应用有什么帮助?
- 你在多线程环境中遇到的常见的问题是什么?你是怎么解决它的?
多线程面试专题答案解析文档截图
二、JVM 面试专题
- 内存模型以及分区,需要详细到每个区放什么。
- 堆里面的分区:Eden,survival (from+ to),老年代,各自的特点。
- 对象创建方法,对象的内存分配,对象的访问定位。
- GC 的两种判定方法:
- SafePoint 是什么
- GC 的三种收集方法:标记清除、标记整理、复制算法的原理与特点,分别用在什么地方,如果让你优化收集方法,有什么思路?
- GC 收集器有哪些?CMS 收集器与 G1 收集器的特点。
- Minor GC 与 Full GC 分别在什么时候发生?
- 几种常用的内存调试工具:jmap、jstack、jconsole、jhat
- 类加载的几个过程:
- 如何判断一个对象是否存活?(或者 GC 对象的判定方法)
- 简述 java 垃圾回收机制?
- java 内存模型
- 简述 java 类加载机制?
- 类加载器双亲委派模型机制?
- 什么是类加载器,类加载器有哪些?
- 简述 java 内存分配与回收策略以及 Minor GC 和 Major GC
JVM 面试专题答案解析文档截图
三、Spring 面试专题
- 什么是 Spring 框架?Spring 框架有哪些主要模块?
- 使用 Spring 框架能带来哪些好处?
- 什么是控制反转(IOC)?什么是依赖注入?
- 请解释下 Spring 框架中的 IoC?
- BeanFactory 和 ApplicationContext 有什么区别?
- Spring 有几种配置方式?
- 如何用基于 XML 配置的方式配置 Spring?
- 如何用基于 Java 配置的方式配置 Spring?
- 怎样用注解的方式配置 Spring?
- 请解释 Spring Bean 的生命周期?
- Spring Bean 的作用域之间有什么区别?
- 什么是 Spring inner beans?
- Spring 框架中的单例 Beans 是线程安全的么?
- 请举例说明如何在 Spring 中注入一个 Java Collection?
- 如何向 Spring Bean 中注入一个 Java.util.Properties?
- 请解释 Spring Bean 的自动装配?
- 请解释自动装配模式的区别?
- 如何开启基于注解的自动装配?
- 请举例解释 @Required 注解?
- 请举例解释 @Autowired 注解?
- 请举例说明 @Qualifier 注解?
- 构造方法注入和设置注入有什么区别?
- Spring 框架中有哪些不同类型的事件?
- FileSystemResource 和 ClassPathResource 有何区别?
- Spring 框架中都用到了哪些设计模式?
Spring 面试专题答案解析文档截图
四、Spring Cloud、Spring Boot、SpringMVC 面试专题
1)Spring Cloud 面试专题
- 什么是 Spring Cloud?
- 使用 Spring Cloud 有什么优势?
- 服务注册和发现是什么意思?Spring Cloud 如何实现?
- 负载平衡的意义什么?
- 什么是 Hystrix?它如何实现容错?
- 什么是 Hystrix 断路器?我们需要它吗?
- 什么是 Netflix Feign?它的优点是什么?
- 什么是 Spring Cloud Bus?我们需要它吗?
2)Spring Boot 面试专题
- 什么是 Spring Boot?
- Spring Boot 有哪些优点?
- 什么是 JavaConfig?
- 如何重新加载 Spring Boot 上的更改,而无需重新启动服务器?
- Spring Boot 中的监视器是什么?
- 如何在 Spring Boot 中禁用 Actuator 端点安全性?
- 如何在自定义端口上运行 Spring Boot 应用程序?
- 什么是 YAML?
- 如何实现 Spring Boot 应用程序的安全性?
- 如何集成 Spring Boot 和 ActiveMQ?
- 如何使用 Spring Boot 实现分页和排序?
- 什么是 Swagger?你用 Spring Boot 实现了它吗?
- 什么是 Spring Profiles?
- 什么是 Spring Batch?
- 什么是 FreeMarker 模板?
- 如何使用 Spring Boot 实现异常处理?
- 您使用了哪些 starter maven 依赖项?
- 什么是 CSRF 攻击?
- 什么是 WebSockets?
- 什么是 AOP?
- 什么是 Apache Kafka?
- 我们如何监视所有 Spring Boot 微服务?
Spring Boot 面试专题答案解析文档截图
3)Spring MVC 面试专题
- 什么是 SpringMvc?
- Spring MVC 的优点:
- SpringMVC 工作原理?
- SpringMVC 流程?
- SpringMvc 的控制器是不是单例模式,如果是,有什么问题,怎么解决?
- 如果你也用过 struts2.简单介绍下 springMVC 和 struts2 的区别有哪些?
- SpingMvc 中的控制器的注解一般用哪个,有没有别的注解可以替代?
- @RequestMapping 注解用在类上面有什么作用?
- 怎么样把某个请求映射到特定的方法上面?
- 如果在拦截请求中,我想拦截 get 方式提交的方法,怎么配置?
- 怎么样在方法里面得到 Request,或者 Session?
- 我想在拦截的方法里面得到从前台传入的参数,怎么得到?
- 如果前台有很多个参数传入,并且这些参数都是一个对象的,那么怎么样快速得到这个对象?
- SpringMvc 中函数的返回值是什么?
- SpringMVC 怎么样设定重定向和转发的?
- SpringMvc 用什么对象从后台向前台传递数据的?
- SpringMvc 中有个类把视图和数据都合并的一起的,叫什么?
- 怎么样把 ModelMap 里面的数据放入 Session 里面?
- SpringMvc 怎么和 AJAX 相互调用的?
- 当一个方法向 AJAX 返回特殊对象,比如 Object,List 等,需要做什么处理?
- SpringMvc 里面拦截器是怎么写的
- 讲下 SpringMvc 的执行流程
五、Redis 面试专题 50 问
- 什么是 Redis?
- Redis 相比 memcached 有哪些优势?
- Redis 支持哪几种数据类型?
- Redis 主要消耗什么物理资源?
- Redis 的全称是什么?
- Redis 有哪几种数据淘汰策略?
- Redis 官方为什么不提供 Windows 版本?
- 一个字符串类型的 值 能 存储最大容量是多少?
- 为什么 Redis 需要把所有数据放到内存中?
- Redis 集群方案应该怎么做?都有哪些方案?
- Redis 集群方案什么情况下会导致整个集群不可用?
- MySQL 里有 2000w 数据,Redis 中只存 20w 的数据,如何保证 Redis 中的数据都是热点数据?
- Redis 有哪些适合的场景?
- Redis 支持的 Java 客户端都有哪些?官方推荐用哪个?
- Redis 和 Redisson 有什么关系?
- Jedis 与 Redisson 对比有什么优缺点?
- Redis 如何设置密码及验证密码?
- 说说 Redis 哈希槽的概念?
- Redis 集群的主从复制模型是怎样的?
- Redis 集群会 有 写 操作丢失吗?为什么?
- Redis 集群之间是如何复制的?
- Redis 集群最大节点个数是多少?
- Redis 集群如何选择数据库?
- 怎么测试 Redis 的连通性?
- Redis 中的管道有什么用?
- 怎么理解 Redis 事务?
- Redis 事务相关的命令有哪几个?
- Redis key 的过期时间和永久有效分别怎么设置?
- Redis 如何做内存优化?
- Redis 回收进程如何工作的?
- Redis 回收使用的是什么算法?
- Redis 如何做大量数据插入?
- 为什么要做 Redis 分区?
- 你知道有哪些 Redis 分区实现方案?
- Redis 分区有什么缺点?
- Redis 持久化数据和缓存怎么做扩容?
- 分布式 Redis 是前期做还是后期规模上来了再做好?为什么?
- Twemproxy 是什么?
- 支持一致性哈希的客户端有哪些?
- Redis 与其他 key-value 存储有什么不同?
- Redis 的内存占用情况怎么样?
- 都有哪些办法可以降低 Redis 的内存使用情况呢?
- 查看 Redis 使用情况及状态信息用什么命令?
- Redis 的内存用完了会发生什么?
- Redis 是单线程的,如何提高多核 CPU 的利用率?
- 一个 Redis 实例最多能存放多少的 keys?List、Set、Sorted Set 他们最多能存放多少元素?
- Redis 常见性能问题和解决方案?
- Redis 提供了哪几种持久化方式?
- 如何选择合适的持久化方式?
- 修改配置不重启 Redis 会实时生效吗?
Redis 面试专题答案解析文档截图
六、RabbitMQ 面试专题
- RabbitMQ 中的 broker 是指什么?cluster 又是指什么?
- 什么是元数据?元数据分为哪些类型?包括哪些内容?与 cluster 相关的元数据有哪些?元数据是如何保存的?元数据在 cluster 中是如何分布的?
- RAM node 和 disk node 的区别?
- RabbitMQ 上的一个 queue 中存放的 message 是否有数量限制?
- RabbitMQ 概念里的 channel、exchange 和 queue 这些东东是逻辑概念,还是对应着进程实体?这些东东分别起什么作用?
- vhost 是什么?起什么作用?
- 在单 node 系统和多 node 构成的 cluster 系统中声明 queue、exchange ,以及进行 binding 会有什么不同?
- 客户端连接到 cluster 中的任意 node 上是否都能正常工作?
- 若 cluster 中拥有某个 queue 的 owner node 失效了,且该 queue 被声明具有 durable 属性,是否能够成功从其他 node 上重新声明该 queue ?
- cluster 中 node 的失效会对 consumer 产生什么影响?若是在 cluster 中创建了 mirrored queue ,这时 node 失效会对 consumer 产生什么影响?
- 能够在地理上分开的不同数据中心使用 RabbitMQ cluster 么?
- 为什么 heavy RPC 的使用场景下不建议采用 disk node ?
- 向不存在的 exchange 发 publish 消息会发生什么?向不存在的 queue 执行 consume 动作会发生什么?
- routing_key 和 binding_key 的最大长度是多少?
- RabbitMQ 允许发送的 message 最大可达多大?
- 什么情况下 producer 不主动创建 queue 是安全的?
- “dead letter”queue 的用途?
- 为什么说保证 message 被可靠持久化的条件是 queue 和 exchange 具有 durable 属性,同时 message 具有 persistent 属性才行?
- 什么情况下会出现 blackholed 问题?
- 如何防止出现 blackholed 问题?
- Consumer Cancellation Notification 机制用于什么场景?
- Basic.Reject 的用法是什么?
- 为什么不应该对所有的 message 都使用持久化机制?
- RabbitMQ 中的 cluster、mirrored queue,以及 warrens 机制分别用于解决什么问题?存在哪些问题?
RabbitMQ 面试专题答案解析文档截图
七、Nginx、Netty 面试专题
1)Nginx 面试专题
- 解释一下什么是 Nginx?
- 请列举 Nginx 的一些特性。
- 请列举 Nginx 和 Apache 之间的不同点
- 请解释 Nginx 如何处理 HTTP 请求。
- 在 Nginx 中,如何使用未定义的服务器名称来阻止处理请求?
- 使用“反向代理服务器”的优点是什么?
- 请列举 Nginx 服务器的最佳用途。
- 请解释 Nginx 服务器上的 Master 和 Worker 进程分别是什么?
- 请解释你如何通过不同于 80 的端口开启 Nginx?
- 解释是否有可能将 Nginx 的错误替换为 502 错误、503?
- 在 Nginx 中,解释如何在 URL 中保留双斜线?
- 请解释 ngx_http_upstream_module 的作用是什么?
- 请解释什么是 C10K 问题?
- 请陈述 stub_status 和 sub_filter 指令的作用是什么?
- 解释 Nginx 是否支持将请求压缩到上游?
- 解释如何在 Nginx 中 获得当前的时间?
- 用 Nginx 服务器解释-s 的目的是什么?
- 解释如何在 Nginx 服务器上添加模块?
2)Netty 面试专题
- BIO、NIO 和 AIO 的区别?
- NIO 的组成?
- Netty 的特点?
- Netty 的线程模型?
- TCP 粘包/拆包的原因及解决方法?
- 了解哪几种序列化协议?
- 如何选择序列化协议?
- Netty 的零拷贝实现?
- Netty 的高性能表现在哪些方面?
- NIOEventLoopGroup 源码?
八、数据结构面试专题
- ConcurrentHashMap 为何读不加锁。
- HashMap 如何同步。
- 说说常见的集合有哪些吧。
- HashMap 与 HashTable 的区别。
- HashMap 的 put 方法的具体流程。
- HashMap 的扩容操作是怎么实现的。
- HashMap 是怎么解决哈希冲突的。
- HashMap 为什么不直接使用 hashCode()处理后的哈希值之直接作为 table 的下标。
- 为什么 HashMap 中 String、Integer 这样的包装类适合作为 Key。
- ConcurrentHashMap 和 HashMap 的区别。
- Java 集合的快速失败机制“fail-fast”,以及安全失败“fail-safe”。
- ArrayList 和 CopyOnWriteArrayList 的区别。
- ArrayList 和 LinkedList 的区别。
- HashSet 是如何保证数据不可重复的。
- BlockingQueue 是什么。
- HashMap 为什么选用红黑树。
- Iterator 中是否存在 Add 方法。