前段时间刚面试上岸,先后面试了各大小公司,拿了一些 offer,有阿里,滴滴,快手,达达,得物等公司。面试的公司大部分都能过,所以这里给大家分享下自己的经验,也给自己做个归档,希望能给正在准备跳槽,找工作的朋友一点帮助,这里主要分享下阿里面试的经历!
!!以上提及到的所有的笔记内容、面试题、简历等资料,均可以在公众号【退休程序猿】上免费分享给大家学习!!
阿里一面
- 自我介绍,聊项目, 这边挺常规的,从项目入手。
- 解析 Excel 为什么用 POI ? POI 存在的问题?
- 还知道哪些解析 Excel 的工具吗?
- 你们项目中用过 MQ,平时都用 MQ 来做什么?
- 你处理过 MQ 得幂等问题,当时是怎么做的?
- MQ 的可靠性怎么保证?
- redis 你们都用来做什么?
- redis 的持久化机制?
- 怎么样保证 redis 的高可用?
- HashMap 和 ConcurrentHashMap 的区别?
- ConcurrentHashMap 不同版本的差异?
- 用过多线程吗?
- 多线程的几种实现方式。
- 做过微服务开发吗?
- 说一说对重构的看法
- 有什么问题要问我的吗?
时间不长,大概二十分钟,面试官人不错。一面结果通过。
阿里二面
过了一个星期,由于当地有阿里的子公司,就去了子公司的会议室进行视频面试。
二面看上去是个组长的人,年纪并不轻。同样的自我介绍开始,然后聊来深圳发展的意愿,个人的情况,然后问了一下做的项目,就开始问问题了。
- 项目中处理了哪些格式的数据类型?
- 数据传输过程用的什么加密?
- 对称加密和非对称加密的区别?
- http 和 https 的区别?
- 为什么 https 使用混合加密的方式?
- 说一说 JVM 调优的思路及你是怎么样调优的。
- JVM 常见的算法。
- 抽象类和接口的区别和应用场景? ( 挺新鲜的,第- -)次碰到 )
- 平时有没有用到什么设计模式?
- 看过什么源码没有?
- 什么是 SpringAOP?
- AOP 实现的原理。
- sql优化的思路。
- 索弓|实现原理。
- 有时候索引失效,为什么?
- 问了我期望薪资,本来说月薪了,后面他说他们那里是按年薪算的。然后让我等一下 ,他去找部长去概去了二十分钟。
二面结果:通过。
阿里三面
- 自我介绍,然后开始聊项目。
- 数据采集的时候有没有对数据进行校验?
- 有没有做加密处理?
- 对称加密和非对称加密的区别?
- 如何保证数据不丢失呢? ( 对账)
- 你们项目中 redis 用来干什么了?
- redis 常用的数据类型?
- redis 持久化机制?
- 分布式锁的实现?
- 场景题:一个 SQL 的 TOP N 问题
- JVM 参数调优及 JVM 内存结构。
- 常见的垃圾回收算法。
- dubbo 整个调用过程。
- SpringMVC、Spring 和 SpringBoot 的区别 ?
- 线程池实现原理。
- sql 优化的思路。
- 索弓|实现原理。
- 聚簇索引和非聚簇索引的区别。
- 你有什么要问我的吗? ( 你是部长?他说不是,部长授权面试。)
阿里四面
过了一个星期,收到电话面试,各位以为是 HR 面,错了,这个叫业务经理面。HR 说这个一 般都能过。
- 自我介绍,说一个你最熟悉的项目, 你在其中承担什么样的角色,开发过程中碰到最大的难题是什么?
- 聊一聊 SOA 和微服务。
- 大学挂过科没有。
- 哪科学得最好。大概总共聊了 15 分钟左右。
四面结果:通过。
阿里五面
又过了一个星期。才到 HR 面,是当地子公司视频面试。
- 自我介绍,项目类型。
- 为什么考虑到深圳发展?
- 为什么选择平安银行?
- 现在在面试哪些公司?
- 如何规划自己的生活?
- 期望薪资。
如何快速搞定 Java 面试,总体上做好以下三点即可:
- 简历准备
- 核心技术及面试题
- 面试技巧
简历准备
首先你要准备的是简历。简历很重要,这是别人了解你的第一个地方,所以简历要好好写。
自我简介:用最简单的话来说明自己的情况,不超过 200 字。比如: 10+ 年的软件开发经验(说明你的主业),4+年的团队 leader 经验(说明你的领导力),擅长高可用高性能的分布式架构(说明你的专业和专攻),多年互联网和金融行业背景(说明你的行业背景),任职于 XXX 公司的 XX 职位(说明你的职业),负责 XXX 平台或系统(说明你的业务场景)....
个人技能:让对方了解你掌握的技术和熟悉的领域。如 JVM、并发编程、Redis、 Spring 源码、分布式系统架构、高性能调优等
经验和软技能:带过多少人的团队、有多少年的项目管理经验、学习能力如何、执行力怎么样、设计过什么样的系统。(不要太多,几句话就好)
工作经历:不要列一大堆项目,挑重要的,主要突出项目的难度(技术点)、规模(用户量、并发量、吞吐量)、挑战(高可用、技术瓶颈及突破)、职责(项目经历/核心开发)等。
核心技术及面试题
核心技术
- 面试常考的核心知识点包括以下点:
- 基础类:并发编程、JVM、网络与 IO、sql 优化、数据结构与算法
- 开源框架:Spring 源码、Mybiats 源码
- 高性能架构技术:Redis、MQ、Kafka、zookeeper、ES、docker
- 分布式与微服务:Dubbo、SpringBoot、SpringCloud、SpringCloud Alibaba
- 快速学习线路推荐 1:并发编程+JVM (1 个月)、Spring 源码(1个月)、Redis+MQ+SpringBoot 和 SpringCloud(1个月)
- 快速学习线路推荐 2:并发编程+JVM+IO+Sql(2 个月)、Spring 源码(1 个月)、Redis+MQ+zookeeper+SpringBoot+SpringCloud(2 个月)数据结构与算法推荐面试前去l eetcode 上刷题
目录大纲
基础篇
多线程&并发篇
Spring 篇
MyBatis 篇
Nginx 篇
分布式篇
SpringCloud篇
Dubbo 篇
Nginx 篇
数据结构与算法篇
Linux 篇
Zookeeper 篇
分布式篇
设计模式
maven 篇
ElasticSearch 篇
软实力篇
Git篇
!!以上提及到的所有的笔记内容、面试题、简历等资料,均可以在公众号【退休程序猿】上免费分享给大家学习!!
好了,本文就写到这了,上述所有题目的答案我都整理成 PDF 了