写点什么

五面阿里成功入职,复盘总结 Java 学习 / 面试自测指南开源分享

发布于: 2021 年 02 月 22 日
五面阿里成功入职,复盘总结Java学习/面试自测指南开源分享

写在前面

准备面试的小伙伴,一定要根据自身情况制定好复习计划! 并且,你最好还要时不时自测一下,对着一些面试常见的问题进行自问。为了方便大家,我分析了百余份 2020 最新大厂面经,整理了面试中最最最常问的一些问题!小伙伴们可以对照着这篇文章学习或者准备面试。


以下所有问题的答案都有相应的解析文档参考,网上也有一些类似的面试题总结的文章,但小编这份绝对是数一数二,剩下你了去网上一个个找的时间!



个知识点都有左侧导航书签页,看的时候十分方便,由于内容较多,这里就截取一部分图吧。需要的读者朋友们可以点赞转发支持一下然后添加小助理 vx:bjmsb2020 即可来获取!


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 基础:


  1. 了解 RPC 吗?有哪些常见的 RPC 框架?

  2. 如果让你自己设计 RPC 框架你会如何设计?

  3. 服务之间的调用为啥不直接用 HTTP 而用 RPC?


Dubbo:


  1. Dubbo 了解吗?

  2. Dubbo 的工作原理了解么?注册中心扮演了什么角色?注册中心挂了可以继续通信吗?

  3. Dubbo 的负载均衡策略了解么?

  4. Dubbo 的 spi 机制了解么?带来了啥好处?



消息队列


  1. 为什么要用消息队列?

  2. 对比一下常见的消息队列?

  3. 如何保证消息不被重复消费?

  4. 如何保证消息消费的顺序性?



分布式 ID


  1. 何为 ID?

  2. 何为分布式 ID?

  3. 一个合格的分布式 ID 需要满足什么要求?

  4. 分布式 ID 常见的生成方法有哪些?(数据库主键自增、数据库的号段模式、UUID、SNOWFLAKE 等等)


其他(网关、限流...)


  1. 为什么要网关?

  2. 为什么要用分布式锁?有哪些实现方式?

  3. 限流的算法有哪些?

  4. 什么是服务熔断?什么是服务降级?

  5. 为什么要分布式 id ?分布式 id 生成策略有哪些?

  6. 微服务下为什么需要链路追踪系统?



数据库

MySQL


基础


  1. 非关系型数据库和关系型数据库的区别?

  2. 事务的四大特性了解么?

  3. MySQL 事务隔离级别?默认是什么级别?

  4. 乐观锁与悲观锁的区别?

  5. MySQL 数据库两种存储引擎的区别?


索引


  1. 为什么索引能提高查询速度?

  2. 聚集索引和非聚集索引的区别?非聚集索引一定回表查询吗?

  3. 索引这么多优点,为什么不对表中的每一个列创建一个索引呢?(使用索引一定能提高查询性能吗?)

  4. 索引底层的数据结构了解么?Hash 索引和 B+树索引优劣分析

  5. B+树做索引比红黑树好在哪里?

  6. 最左前缀匹配原则了解么?

  7. 什么是覆盖索引



Redis


  1. 分布式缓存常见的技术选型方案有哪些?说一下 Redis 和 Memcached 的区别和共同点

  2. 说一下在缓存情况下查询数据和修改数据的流程。

  3. Redis 有哪些数据结构?SDS 了解么?

  4. Redis 内存满了怎么办?

  5. Redis 内存淘汰算法除了 LRU 还有哪些?

  6. Redis 给缓存数据设置过期时间有啥用?Redis 是如何判断数据是否过期的呢?

  7. Redis 事务了解么?(Redis 可以通过 MULTI,EXEC,DISCARD 和 WATCH 等命令来实现事务功能)

  8. 缓存穿透和缓存雪崩问题了解么?有哪些解决办法?

  9. 如何基于 Redis 实现分布式锁?



进阶


  1. 一条 SQL 语句在 MySQL 是如何执行的?

  2. explain 命令了解么?

  3. 简单说一下 SQL 调优思路。

  4. 简单说一下大表优化的思路。

  5. 分库分表了解么?为什么要分库分表?有哪些常见的分库分表工具(sharding-jdbc、TSharding、MyCAT...)?


系统设计/场景题


  1. 假如有 10 亿个数,只有一个重复,内存只能放下 5 亿个数,怎么找到这个重复的数字?

  2. 如何设计一个秒杀系统(服务端、数据库、分布式)?分布式系统的设计?

  3. 有一个服务器专门接收大量请求,怎么设计?

  4. 如果让你自己设计 RPC 框架你会如何设计?

  5. 怎么快速出现一个 stackoverflow 错误?


其他问题


  1. 自我介绍。

  2. 说说你的项目中的亮点有哪些。

  3. 画一下你的项目的架构图。

  4. Restful 了解吗?简单说一下自己对它的认识,如果我要返回一个 boolean 类型的数据怎么办?

经验总结

这是我在工作、面试中学习并总结到的一些知识点,都是一些比较典型的、面试常被问到的问题。如果你平时没有注意去总结的话,那么当你面试被问到的时候可能会是一脸懵圈,就算这个问题你知道怎么回事,但是你平时没有认真总结,你也可能会出现逻辑混乱的情况,从而错失工作机会。


有些知识点不经常使用就会忘记,但是面试还会问,对此,我也是深受其害,所以我决定将这些遇见的问题整理下来,分享出去,帮助更多的人,我们共同进步。所谓“温故而知新”,没事的时候多翻看一下这些知识,没准就会有新的收获。你没时间整理的东西,我都帮你写好了。需要的读者朋友们可以点赞转发支持一下然后添加小助理 vx:bjmsb2020 即可来获取!


发布于: 2021 年 02 月 22 日阅读数: 30
用户头像

领取资料添加小助理vx:bjmsb2020 2020.12.19 加入

Java领域;架构知识;面试心得;互联网行业最新资讯

评论

发布
暂无评论
五面阿里成功入职,复盘总结Java学习/面试自测指南开源分享