做了三年的Java程序员学长说可以内推进阿里,本想尝试下投简历,没想到直接梦圆阿里

前言

事情的过程是这样的,就在前一段时间有学长在群里发布一条消息,说是有阿里内推名额?工作地点在杭州,想要去阿里的同学可以找他,还能帮忙修改简历!
在这里插入图片描述
所以你以为博主拿到阿里的offer了是吗?

然而事实却是:博主深知自己的技术菜,所以只能在这里帮大家见证同学是如何梦圆阿里的了。
以下为同学的这次面试的经历分享。(同学自述)
在这里插入图片描述
在这里插入图片描述

一面(电话面试一小时)

  • 首先做一个简单的自我介绍,主要包括学校经历和工作经历。

  • Java基础。自动拆装箱如何实现,String,StringBuffer,StringBuilder的异同以及各自的实现。

  • JVM基础。JVM的内存模型,常见的垃圾回收算法。

  • 事务ACID,编程时如何保证事务,分布式情况下如何保证事务。

  • 由于分布式相关场景我没有接触过,因此面试官一直诱导我去设计实现一个分布式事务。

  • 数据库乐观锁和悲观锁。如何实现一个乐观锁。

  • 消息队列使用场景,Kafka的架构以及原理。

  • 什么是restful api,和rpc调用有什么区别。

  • 单例的几种写法。volatile关键字有什么作用。

以上就是电话面试的大体问题,面试完之后,又发给我三道算法题目,要求我一小时内完成,下面是三道算法题:

  1. 翻转一个long类型数字。例如输入123456L,输出654321L。- Leetcode翻转integer的变种。考察能否正确处理溢出的情况。

  2. 输入一个double,要求返回与它最接近的.49或.99的数字。例如12.77返回12.99,11.02返回10.99,12.61返回12.49。

  3. 有三个线程ABC分别向一个数组中写入a,l,i,要求最终的写入结果形如alialiali…写入次数由A线程决定。

这三道题目做的还比较顺利,第二天面试官又联系我阐述一下第一题和第三题的思路,然后通知可以参加下一轮了。

二面(电话面试一小时)

  • 二面主要考察了一些开放式的问题。

  • 首先还是自我介绍。主要是工作后的经历。介绍一下工作一年所在team的产品,我承担了什么职责。

  • 开放式问题。如何设计一个rpc框架。

  • 开放式问题。如何设计一个服务注册中心。

  • 集合类源码。HashMap是如何实现的,扩容的过程,为什么要扩容为2倍。HashMap中的链表替换为数组可以吗?时间复杂度相同吗?

  • 集合类源码。线程安全的HashMap是什么?(HashTable和ConcurrentHashMap)ConcurrentHashMap是如何实现的?(Java7分段锁和Java8的CAS+Lock)和HashTable相比有什么优势? 红黑树的结构,时间复杂度是多少,如何计算的.

  • 什么是CAS操作,如何实现一个自定义锁

  • 数据库设计。有一张很大的order表,如何设计能够提升查询效率(同时满足根据买家id和卖家id查询)?

二面也同样是一小时左右,面试过程还算顺利。
ps:一面二面结束后面试官都各种暗示我要疯狂加班能不能接受blabla……

三面(现场面试一个半小时)

二面结束后的第三天,就收到了现场三面的通知。

三面是一个大Boss,因此面试的问题都更考察一些分析问题的能力。

  • 介绍一下你工作一年学习到什么?所在项目的架构是什么样的? 数据隔离级别,脏读幻读。

线程池原理。

  • Synchronized的实现,锁的升级过程。

  • K8s的作用,K8s的底层架构。

  • 对我业余时间做的一些项目做了介绍。

  • 你觉得加入阿里你能给阿里带来什么?

  • 进入阿里你需要忍受很多困难,需要迎难而上,如果绩效考评拿到差评,你会怎么办?

三面总的来说也还算顺利,面试官也算和蔼。

总结

整个流程从一面到三面结束大约持续了10天左右。

总的来说,问题都是他之前遇到过的,所以并没有多难。
不过差点儿在分布式技术这里翻车,但是面试官很耐心的帮忙引导,最终还是说出了自己的思路想法。

最后把学长整理的互联网大厂面试题资料免费分享给大家。

资料领取:戳这里免费领取,暗号:CSDN

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述在这里插入图片描述

听说一键三连的粉丝都面试成功了?如果本篇博客对你有帮助,请支持下博主哦
在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/Lubanjava/article/details/109151030