写点什么

没想到我也可以入职阿里!二本毕业、两年 crud 经验,侥幸通过面试定级 P6

发布于: 1 小时前

对于很多没有学历优势的人来说,面试大厂是非常困难的,这对我而言,也是一样,出身于二本,原本以为就三点一线的生活度过一生,直到生活上的变故,才让我有了新的想法和目标,因此我这个二本渣渣也奋斗了起来,竟拿下了阿里 P6 岗。今天分享这波面经,主要是希望能够激励到同样被学历所困扰的技术人,能够对职业生涯和技术规划有一个参考价值,感谢!

一、面试阿里 P6 难在哪?(面试难点)

(1)难在“心态”

首先需要克服的第一关,实际上就是自己的心态。因为我是二本出身,base 比较低,所以面试阿里本就是一件没太大底气的事情,更何况是高级开发岗,所以心里就更容易没底。因此,在准备面试之前,调整心态这件事情就做了很久,所以难在“心态”一点也没错,心态没调整好,面试几乎是没戏的。

(2)难在“要求”

其次就是要求,所谓的要求实际上就是阿里对岗位的任职要求,也就是作为开发人员,你掌握了多少技术栈?

首先,你简历上写的肯定要会,其次就是你要拥有一些亮点,也就是说对某个技术有深入的了解,这样才能给面试官耳目一新的感觉。

那么,面试阿里 P6 岗,需要掌握多少呢?

  • Java 集合:HashMap 和 ConcurrentHashMap,平时最好有读一些源码,最好知道每个参数为什么设置成这么大?有什么好处?

  • JUC 包肯定要学,即使平时的编程根本不用,也必须得会。至少要知道 aba,cas,aqs,unsafe,volatile,sync,以及常见的各种 lock,死锁,线程池参数等,也必须要明白自旋,阻塞,死锁和它如何去定位,oom 如何定位问题,cpu 过高如何定位等基本的操作,你可以没有生产调试经验,但不代表你可以不会 top,jps,jstack,jmap 这些可能会问的东西。以及可能衍生的 jmm 模型和 mesi 协议等。

  • 大厂必问 JVM:垃圾回收算法,垃圾收集器、JVM 内存模型,每个区域用途,各种 oom 的种类,jvm 调优经验,类加载过程,双亲委派等。

  • Spring 就得抽空看源码了,一般会问到 bean 的生命周期,如何解决循环依赖,实现事务原理,动态代理原理等。

  • Dubbo 也是必须问的,设计框架,负载均衡。

  • Redis 更要多懂一点,单线程模型,aof,rdb,rewrite,主从,cluster,哪些类型?包含一些缓存常见的问题击穿、穿透、雪崩、数据一致性等。

  • Mysql,事务,锁,索引,b+树,主从这些你必须会

  • Mq ,我用的 rocketmq,你得知道为什么用,重复消费,顺序消息,事务消息,高可用,消息丢失,挤压场景,整个消息发送消费的流程,读过源码更佳,更好吹

  • Netty 的话,零拷贝,bio,nio,aio,架构设计怎么样子的?用过看过更好

  • 算法,建议去刷题,我运气好,简单的算法让我碰到了,一些快排,堆排,二叉树相关的,链表反转,成环,环节点,跳楼梯等常规的简单算法建议刷刷,双指针,dp,递归这些还是多找找感觉,大数据内存有限的场景的统计,有时间一些 middle 可以去试试,手写红黑树你要是可以,那我估计算法你稳了。

  • 网络,http,tcp,https,udp,7 层网络协议等,最好结合自己理解,背,你都要背下来。

  • 还有就是一些分布式事务实现,架构实现,比如抢红包,高并发下单等常规的场景设计,你来设计,你怎么去设计?多找一些大牛或者上网自己查,帮你看看有哪些漏洞,有哪些解决方案?业界有哪些好的中间件?


二、阿里面试题(共 5 面)

阿里一面:

  • 自我介绍、自己做的项目和技术领域

  • 说一下 sync 的底层实现,锁优化,和 lock 的对比

  • 讲一下 JVM 参数调优详细过程

  • 为什么这么设置?好处是什么?描述 GC 场景,如何去分析 GC 日志?

  • redis 数据结构,使用场景,微博场景使用 redis 如何去设计用户关系?

  • 线程池参数设定,为什么这么设定,作用?7 大参数

  • spring 的循环依赖如何解决?为什么要三级缓存?

  • 优先级队列的底层原理?

阿里二面:

  • 自我介绍一下吧

  • 聊项目

  • 结合你项目问你如何设计,提出漏洞,你怎么解决?如何改进,万一挂了?加一台机器有没有问题?如果我非要不出问题怎么办?

  • 高并发下单扣库存场景如何设计

  • rocketMQ 架构设计原理

  • Dubbo 框架实现原理

  • 最近读了什么书?平时怎么学习?

  • 常用的负载均衡,该怎么用,你能说下吗?

阿里三面:

  • 这一面主要问项目,给你的压力感比较强

  • 结合项目问,为什么这么设计?让你去优化,你怎么优化,引导你用一个合理的更好的方式去优化,数据库的设计等

  • 在公司做了什么事情,各个系统业务线都是做什么的,你的绩效,手写算法链表反转?

阿里四面:

  • JVM 的主要组成部分及其作用?

  • JVM 运行时数据区包含哪些?

  • JVM 垃圾回收机制,何时触发 MinorGC 等操作

  • JVM 的垃圾回收算法:

  • JVM 调优的工具?

  • 常用的 JVM 调优参数?

  • 堆栈的区别?

  • 详细介绍一下 CMS 垃圾回收器?

  • 怎么判断对象是否可以被回收?

  • 新生代垃圾回收器和老生代垃圾回收器都有哪些?有什么区别?

  • java 类加载过程?

  • 把你知道的中间件都说一下吧(瞬间懵了一下)

HR 面:

  • 为什么来阿里?

  • 之前没考虑过阿里吗?

  • 毕业这么久了,你觉得自己最大的改变是什么?

  • 用一句话总结一下自己

三、面试阿里前,我做了哪些准备。

现在 Java 面试可以说是老生常谈的一个问题了,确实也是这么回事。面试题、面试宝典、面试手册......各种 Java 面试题一搜一大把,根本看不完,也看不过来,而且每份面试资料也都觉得 Nice,然后就开启了收藏之路。

Java 开发者应该是不会很容易满足的,现在拿着 20K 的工作,下一步就想着拿 50K 的 offer,甚至年薪百万都是程序员很常见的,不满足于现状,身在其位就要有担当其位的能力,不断提升技能、技术栈,都是必不可少的!

其实很多人,对本身没有一个清楚的规划,甚至不知道适合什么路线,这样的话,你就会离心仪的 offer 越来越远!无论何时,都需要对自身有一个清楚的认知,你会提前规划一下自己的学习路线吗?



点击并拖拽以移动


如果你有跳槽的打算,不妨停下来,来看一下。可以更加系统、有条理地去复习、备战。

有以下好处:

  • 可以通过一个体系进行复习,解决不知从哪里看起,如何下手?

  • 建立起一个系统的复习体系,每个知识点都是独立且有联系的?

  • 回顾并总结各大厂常考面试点,从自己的实际出发,了解差距在哪?

当然除了这些还有一部分很漂亮的学习资料,总结得很全面的,包含了 29 个知识点,从基础到进阶都有了!篇幅限制就展示了部分内容,需要完整版的小伙伴可以帮忙点赞此文后,点击此处  凭截图免费获取

Java 面试核心知识手册

这份手册我看到的时候就感觉很良心,有 JVM、多线程、Spring 全家桶、微服务、网络、消息中间件、数据结构、算法、分布式等等都包含了:

目录一览

  • JVM



点击并拖拽以移动


  • Java 集合+多线程并发



点击并拖拽以移动


  • Java 基础+Spring 原理+微服务



点击并拖拽以移动


  • Netty 与 RPC+网络



点击并拖拽以移动


  • 日志+Zookeeper+Kafka



点击并拖拽以移动


  • Rabbit+Hbase+MongoDB



点击并拖拽以移动


  • 设计模式+负载均衡



点击并拖拽以移动


  • 数据库+一致性算法



点击并拖拽以移动


  • Java 算法+数据结构+加密算法+分布式缓存



点击并拖拽以移动


  • Hadoop+Spark+Storm



点击并拖拽以移动


  • YARN+机器学习+云计算



点击并拖拽以移动


内容一览

  • 线程



点击并拖拽以移动


  • Java&实现



点击并拖拽以移动


  • Java 线程池工作过程



点击并拖拽以移动


  • Spring



点击并拖拽以移动


  • Netty 与 RPC



点击并拖拽以移动


  • 网络架构



点击并拖拽以移动


  • Rabbit



点击并拖拽以移动


  • 数据库



点击并拖拽以移动


  • 加密算法



点击并拖拽以移动


  • 云计算



点击并拖拽以移动


总结

只有充分地准备好了面试,才可以更有自信地吊打面试官,每方面的知识都是必须的,不能缺乏的。

需要完整版的小伙伴可以帮忙点赞此文后,点击此处  凭截图免费获取

用户头像

还未添加个人签名 2020.09.07 加入

还未添加个人简介

评论

发布
暂无评论
没想到我也可以入职阿里!二本毕业、两年crud经验,侥幸通过面试定级P6