写在前面
准备面试的小伙伴,一定要根据自身情况制定好复习计划! 并且,你最好还要时不时自测一下,对着一些面试常见的问题进行自问。为了方便大家,我分析了百余份 2020 最新大厂面经,整理了面试中最最最常问的一些问题!小伙伴们可以对照着这篇文章学习或者准备面试。
以下所有问题的答案都有相应的解析文档参考,网上也有一些类似的面试题总结的文章,但小编这份绝对是数一数二,剩下你了去网上一个个找的时间!
个知识点都有左侧导航书签页,看的时候十分方便,由于内容较多,这里就截取一部分图吧。需要的读者朋友们可以点击传送门 即可!
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 类型的数据怎么办?
经验总结
这是我在工作、面试中学习并总结到的一些知识点,都是一些比较典型的、面试常被问到的问题。如果你平时没有注意去总结的话,那么当你面试被问到的时候可能会是一脸懵圈,就算这个问题你知道怎么回事,但是你平时没有认真总结,你也可能会出现逻辑混乱的情况,从而错失工作机会。
有些知识点不经常使用就会忘记,但是面试还会问,对此,我也是深受其害,所以我决定将这些遇见的问题整理下来,分享出去,帮助更多的人,我们共同进步。所谓“温故而知新”,没事的时候多翻看一下这些知识,没准就会有新的收获。你没时间整理的东西,我都帮你写好了。有需要的小伙伴点击传送门 即可!