前言
金九银十招聘旺季马上就到了,不知道大家是否准备好了,面对金九银十的招聘旺季,如果没有精心准备那笔者认为那是对自己不负责任;就我们 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
三、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 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 微服务?
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 会实时生效吗?
六、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 机制分别用于解决什么问题?存在哪些问题?
七、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 方法。
目录详览
基础篇
JVM 篇
多线程 &并发篇
Spring 篇
MyBatis 篇
SpringBoot 篇
MySQL 篇
SpringCloud 篇
Dubbo 篇
Nginx 篇
MQ 篇
Linux 篇
Zookeeper 篇
Redis 篇
分布式篇
网络篇
设计模式篇
maven 篇
ElasticSearch 篇
tomcat 篇
Git 篇
软实力篇
内容一览
JVM 知识点汇总
锁、线程
Mybatis
Zookeeper
TCP
总结
以上就是有关程序员面试专题的一些总结,面试不仅考的是技术还有心态,只要你有足够的技术支撑,心态要好,拿到 offer 肯定不在话下。先不要把它想得很困难,自己给自己设置槛!希望大家都可以拿到心仪 offer,走向升职、跳槽、涨薪、赢娶白富美之路!