其他
我花了一周,总结了一份Java学习/面试自测指南!200+道Java最常见面试题!
开始之前,先说一下我非常推荐的一种学习方式:
带着问题学习或者准备面试。
另外,准备面试的小伙伴,一定要根据自身情况制定好复习计划! 并且,你最好还要时不时自测一下,对着一些面试常见的问题进行自问。
为了方便大家,我分析了百余份 2020 最新大厂面经,整理了面试中最最最常问的一些问题!小伙伴们可以对照着这篇文章学习或者准备面试。
网上也有一些类似的面试题总结的文章,大家以我这篇为准就好!毫不吹牛,Guide哥 整理,质量有保障!(基于事实的自信 😎)
另外,内容会继续完善,欢迎你在评论区说出你遇到的高频面试题!
以下所有问题的答案可以参考(大部分都能找到):JavaGuide[1](「Java 学习+面试指南」一份涵盖大部分 Java 程序员所需要掌握的核心知识。准备 Java 面试,首选 JavaGuide!)。
Java
基础
Java 基础这部分有一些太简单的问题就直接没有放上来。小伙伴们可以参考: Java 基础知识点总结[2]。
Java 中的几种基本数据类型是什么?对应的包装类型是什么?各自占用多少字节呢? String
、 StringBuffer
和StringBuilder
的区别是什么?String
为什么是不可变的?== 与 equals?hashCode 与 equals ? Java 反射?反射有什么缺点?你是怎么理解反射的(为什么框架需要反射)? 谈谈对 Java 注解的理解,解决了什么问题? Java 泛型了解么?什么是类型擦除?介绍一下常用的通配符? 内部类了解吗?匿名内部类了解吗? BIO,NIO,AIO 有什么区别?
Java 集合框架
说说 List,Set,Map 三者的区别?三者底层的数据结构? 有哪些集合是线程不安全的?怎么解决呢? 比较 HashSet、LinkedHashSet 和 TreeSet 三者的异同 HashMap 和 Hashtable 的区别?HashMap 和 HashSet 区别?HashMap 和 TreeMap 区别? HashMap 的底层实现 HashMap 的长度为什么是 2 的幂次方 ConcurrentHashMap 和 Hashtable 的区别? ConcurrentHashMap 线程安全的具体实现方式/底层具体实现
jvm
jvm 内存结构 jvm 调优参数 什么是类加载?何时类加载?类加载流程? 知道哪些类加载器。类加载器之间的关系? 类加载器的双亲委派了解么?结合 Tomcat 说一下双亲委派(Tomcat 如何打破双亲委托机制?...)。 为什么需要双亲委派 Java 内存模型 栈中存放什么数据,堆中呢? 大对象放在哪个内存区域 堆区如何分类 垃圾回收有哪些算法 GC 的全流程 GC 中老年代用什么回收方法?
多线程
线程和进程的区别。 什么是上下文切换? 什么是线程死锁?如何避免死锁? 乐观锁和悲观锁了解么? 说说 sleep()
方法和wait()
方法区别和共同点?Java 线程池有哪些参数?阻塞队列有几种?拒绝策略有几种?新线程添加的流程? 实现 Runnable
接口和Callable
接口的区别。讲一下 JMM(Java 内存模型)。 volatile
关键字解决了什么问题?说说synchronized
关键字和volatile
关键字的区别。AQS 原理了解么?AQS 组件有哪些? 用过 CountDownLatch 么?什么场景下用的?
网络
OSI 与 TCP/IP 各层的结构与功能,都有哪些协议?为什么网络要分层? 计算机网络的一些常见状态码 ping 所使用的协议 TCP 的三次握手与四次挥手的内容?TCP 为什么连接是三次握手而断开是四次握手? TCP 与 UDP 的区别及使用场景 TCP 是如何保证传输的可靠性? 一次完整的 HTTP 请求所经的步骤 HTTP 协议了解么?HTTP 是基于 TCP 还是 UDP 的? HTTP 报文的内容简单说一下!HTTP 请求报文和响应报文中有哪些数据? HTTP 和 HTTPS 的区别了解么? HTTP 请求有哪些常见的状态码? HTTP 长连接和短连接了解么? Cookie 和 Session 的关系 URI 和 URL 的区别是什么?
算法和数据结构
算法
LRU 算法了解吗?你能实现一个吗? 写排序算法(快排、堆排) 使用数组实现一个栈 使用数组实现一个队列 实现一个链表、反转链表、 ......
数据结构
数组 vs 链表 栈的应用场景 队列的分类、应用场景 红黑树的特点、红黑树 vs 二叉查找树 哈希表、哈希表应用场景 布隆过滤器了解吗? ......
系统设计
设计模式
何为设计模式?有哪些常见的设计模式? 单例模式了解么?说一下单例模式的使用场景。手写一个单例模式的实现。 观察者模式了解么?说一下观察者模式的使用场景。 工厂模式了解么?说一下工厂模式的使用场景。 责任链模式了解么?哪些开源项目(Netty、MyBatis ...)中用到了责任链模式?怎么用的? SOLID 原则了解么?简单谈谈自己对于单一职责原则和开闭原则的理解。 阅读 Spring 源码的时候什么设计模式最让你影响深刻?能简单讲讲吗?
常见框架
Spring
什么是 Spring 框架? 列举一些重要的 Spring 模块? 谈谈自己对于 Spring IoC 和 AOP 的理解 Spring Bean 的生命周期说一下 Spring 中的 bean 的作用域有哪些? 拦截器和过滤器了解么? Spring 动态代理默认用哪一种 hibernate 和 mybatis 区别 Spring Boot 和 Spring 的区别 说出使用 Spring Boot 的主要优点 什么是 Spring Boot Starter? 介绍一下 @SpringBootApplication
注解Spring Boot 的自动配置是如何实现的? Spring Boot 支持哪些嵌入式 web 容器?
Netty
BIO,NIO 和 AIO 有啥区别? Netty 是什么?为啥不直接用 NIO 呢? 为什么要用 Netty?Netty 应用场景了解么? 介绍一下 Netty 的核心组件? Bootstrap 和 ServerBootstrap 了解么? NioEventLoopGroup 默认的构造函数会起多少线程? Netty 线程模型了解么? 什么是 TCP 粘包/拆包?有什么解决办法呢? Netty 长连接、心跳机制了解么?
权限认证
认证 (Authentication) 和授权 (Authorization)的区别是什么? 什么是 Cookie ? Cookie 的作用是什么?如何在服务端使用 Cookie ? Cookie 和 Session 有什么区别?如何使用 Session 进行身份验证? 如果没有 Cookie 的话 Session 还能用吗? 为什么 Cookie 无法防止 CSRF 攻击,而 token 可以? 什么是 Token?什么是 JWT?如何基于 Token 进行身份验证? 什么是 OAuth 2.0? 什么是 SSO(单点登录)?
微服务/分布式
RPC
RPC 基础:
了解 RPC 吗?有哪些常见的 RPC 框架? 如果让你自己设计 RPC 框架你会如何设计? 服务之间的调用为啥不直接用 HTTP 而用 RPC?
Dubbo:
Dubbo 了解吗? Dubbo 的工作原理了解么?注册中心扮演了什么角色?注册中心挂了可以继续通信吗? Dubbo 的负载均衡策略了解么? Dubbo 的 spi 机制了解么?带来了啥好处?
消息队列
为什么要用消息队列? 对比一下常见的消息队列? 如何保证消息不被重复消费? 如何保证消息消费的顺序性?
分布式 ID
何为 ID? 何为分布式 ID? 一个合格的分布式 ID 需要满足什么要求? 分布式 ID 常见的生成方法有哪些?(数据库主键自增、数据库的号段模式、UUID、SNOWFLAKE 等等)
其他(网关、限流...)
为什么要网关? 为什么要用分布式锁?有哪些实现方式? 限流的算法有哪些? 什么是服务熔断?什么是服务降级? 为什么要分布式 id ?分布式 id 生成策略有哪些? 微服务下为什需要链路追踪系统?
数据库
MySQL
基础
非关系型数据库和关系型数据库的区别? 事务的四大特性了解么? MySQL 事务隔离级别?默认是什么级别? 乐观锁与悲观锁的区别? MySQL 数据库两种存储引擎的区别?
索引
为什么索引能提高查询速度? 聚集索引和非聚集索引的区别?非聚集索引一定回表查询吗? 索引这么多优点,为什么不对表中的每一个列创建一个索引呢?(使用索引一定能提高查询性能吗?) 索引底层的数据结构了解么?Hash 索引和 B+树索引优劣分析 B+树做索引比红黑树好在哪里? 最左前缀匹配原则了解么? 什么是覆盖索引
Redis
分布式缓存常见的技术选型方案有哪些?说一下 Redis 和 Memcached 的区别和共同点 说一下有缓存情况下查询数据和修改数据的流程。 Redis 有哪些数据结构?SDS 了解么? Redis 内存满了怎么办? Redis 内存淘汰算法除了 LRU 还有哪些? Redis 给缓存数据设置过期时间有啥用?Redis 是如何判断数据是否过期的呢? Redis 事务了解么?(Redis 可以通过 MULTI,EXEC,DISCARD 和 WATCH 等命令来实现事务功能) 缓存穿透和缓存雪崩问题了解么?有哪些解决办法? 如何基于 Redis 实现分布式锁?
进阶
一条 SQL 语句在 MySQL 中如何执行的? explain 命令了解么? 简单说一下 SQL 调优思路。 简单说一下大表优化的思路。 分库分表了解么?为什么要分库分表?有哪些常见的分库分表工具( sharding-jdbc
、TSharding
、MyCAT
...)?
系统设计/场景题
假如有 10 亿个数,只有一个重复,内存只能放下 5 亿个数,怎么找到这个重复的数字? 如何设计一个秒杀系统(服务端、数据库、分布式)?分布式系统的设计? 有一个服务器专门接收大量请求,怎么设计? 如果让你自己设计 RPC 框架你会如何设计? 怎么快速出现一个 stackoverflow 错误?
其他问题
自我介绍。 说说你的项目中的亮点有哪些。 画一下你的项目的架构图。 Restful 了解吗?简单说一下自己对它的认识,如果我要返回一个 boolean 类型的数据怎么办?
经验总结
多面试,不要害怕失败,多总结经验。 尽早准备,不论是找工作前、面试前还是面试后。 熟悉自己的简历。 电话和视频面试很平常,面试前提前准备一下。 坚持!offer 虽然可能会迟到,但是只要不放弃,就一定不会缺席。
参考资料
[1]JavaGuide: https://github.com/Snailclimb/JavaGuide
[2]Java 基础知识点总结: https://github.com/Snailclimb/JavaGuide/blob/master/docs/java/Java基础知识.md
推荐👍:V4.0 《JavaGuide 面试突击版》来啦!年初搞波大的
推荐👍: Github掘金计划:Github上的一些优质项目搜罗