阿里三面,复盘总结55题:java基础+分布式+网络+架构设计
阿里一面
- 自我介绍
- 链表,数组的优缺点,应用场景,查找元素的复杂度
- 二叉树怎么实现的
- Java中都有哪些锁
- 可重入锁的设计思路是什么
- 乐观锁和悲观锁
- synchronized机制
- hashmap原理,处理哈希冲突用的哪种方法(拉链)
- 还知道什么处理哈希冲突的方法(开放地址检测)
- 开放地址检测怎么实现的
- 从哈希表中删除一个元素,再加入元素时恰好与原来那个哈希冲突,这个元素会放在哪
- 并发容器,Hashtable和concurrenthashmap区别
- redis原子操作怎么用比较好
- 消息队列用过哪些?
阿里二面
操作系统模块:
- 说一下并行和并发的区别
- 你知道进程吗?有进程为何还有线程?
- 操作系统是如何调度进程呢的
- 比如linux下我打开一个文件调用read函数,整个过程说的越细越好
- 同步异步阻塞非阻塞IO详细越好。
网络模块:
- TCP报文格式
- TCP和UDP
- 拥塞控制
- 超时重传
- 三次握手
- 滑动窗口
- 常见协议的端口号
数据库模块:
- 索引数据结构
- 索引常见优化方案
- 存储引擎
- 事务(spring框架如何实现事务的呢)
- 垂直拆分
- 分库分表
- 读写分离
Java模块:
- hashmap
- Arraylist和linkedlist
- voliate
- 线程池,如何根据CPU的核数来设计线程大小,如果是计算机密集型的呢,如果是IO密集型的呢?
- countdownlatch和CyclicBarrier底层实现原理
- 线程状态以及API怎么操作会发生这种转换
JVM模块
面试官说只问三个问题:
- 内存模型以及分区,需要详细到每个区放什么
- 堆里面的分区:Eden,survival ,老年代,各自的特点。
- 垃圾回收算法,什么时候回收。
分布式:
- redis与memached选型,你更倾向于选择哪个,为什么?
- 分布式事务解决,你知道我们阿里巴巴是怎么做的吗?
- 消息队列比较和选型?
- CAP
阿里三面
- 自我介绍
- 学习技术的方式,开源、书籍、自学、实践,具体的学习方法?
- 最有技术含量的项目,讲讲从架构设计再到部署的流程
- 常见的数据库瓶颈有哪些,怎么来优化
- 微信附件人这个功能怎么实现的
HR面(略)
以上就是阿里三面题目,以下是总结出来的阿里经典面试题目及答案,内容涵盖: Java、MyBatis、ZooKeeper、Dubbo、Elasticsearch、Memcached、Redis、MySQL、Spring、Spring Boot、Spring Cloud、RabbitMQ、Kafka、Linux等技术栈。
有需要获取到借鉴复习的小伙伴:一键三连(点赞+收藏+关注) 后,私信我【阿里面试资料】即可(一定记得关注我 不然不能回复陌生人私信的)