算法和数据结构
=======
-
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 长连接、心跳机制了解么?
微服务/分布式
=======
RPC
RPC 基础:
-
了解 RPC 吗?有哪些常见的 RPC 框架?
-
如果让你自己设计 RPC 框架你会如何设计?
-
服务之间的调用为啥不直接用 HTTP 而用 RPC?
Dubbo:
-
Dubbo 了解吗?
-
Dubbo 的工作原理了解么?注册中心扮演了什么角色?注册中心挂了可以继续通信吗?
-
Dubbo 的负载均衡策略了解么?
-
Dubbo 的 spi 机制了解么?带来了啥好处?
消息队列
-
为什么要用消息队列?
-
对比一下常见的消息队列?
-
如何保证消息不被重复消费?
-
如何保证消息消费的顺序性?
数据库
===
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 错误?
其他问题
总结
互联网大厂比较喜欢的人才特点:对技术有热情,强硬的技术基础实力;主动,善于团队协作,善于总结思考。无论是哪家公司,都很重视高并发高可用技术,重视基础,所以千万别小看任何知识。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。其实我写了这么多,只是我自己的总结,并不一定适用于所有人,相信经过一些面试,大家都会有这些感触。
**另外本人还整理收藏了2021年多家公司面试知识点以及各种技术点整理 **
下面有部分截图希望能对大家有所帮助。
个秒杀系统(服务端、数据库、分布式)?分布式系统的设计?
-
有一个服务器专门接收大量请求,怎么设计?
-
如果让你自己设计 RPC 框架你会如何设计?
-
怎么快速出现一个 stackoverflow 错误?
其他问题
总结
互联网大厂比较喜欢的人才特点:对技术有热情,强硬的技术基础实力;主动,善于团队协作,善于总结思考。无论是哪家公司,都很重视高并发高可用技术,重视基础,所以千万别小看任何知识。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。其实我写了这么多,只是我自己的总结,并不一定适用于所有人,相信经过一些面试,大家都会有这些感触。
**另外本人还整理收藏了2021年多家公司面试知识点以及各种技术点整理 **
下面有部分截图希望能对大家有所帮助。
[外链图片转存中…(img-SqGzUrHa-1714165328943)]