阿里天猫团队5面Java面经:索引+高并发+分库分表+线程池

阿里天猫团队5面Java面经:索引+高并发+分库分表+线程池

一面

一面都是聊项目,聊了半个小时,主要包括这几个问题:

  • 项目介绍
  • 项目中如何对数据库进行优化
  • 项目中的难点
  • 你在项目中充当的角色

和面试官聊了35分钟,大部分时间是我在介绍,我把项目中自己负责的部分很详细地说了出来。面试官很友好,对我给予了肯定,直接和我说通过了一面。两个小时后就约二面面试时间了......

二面

  • 自我介绍
  • 分别介绍一下你的几个项目
  • 你觉得哪个项目让你印象最深刻?
  • 项目中一些关于 geohash 的问题
  • 分库分表的依据是什么?有用什么工具吗?
  • 线程的几种状态?
  • wait和sleep分别属于哪个类的方法
  • lock和synchronized的区别是什么
  • 什么情况下适合用偏向锁?
  • BIO和NIO的区别是什么?分别适合于什么场景?
  • select 和 epoll的区别
  • 说一下你知道的Http的请求头和返回码
  • String s = new String("abc") 产生了几个对象?分别放在哪里?
  • 上面那行代码在JDK1.8前后存放的区域有什么不同?
  • 平时有用什么工具观察过虚拟机的内存情况吗?
  • 平时怎么学习的?有没有关注什么博客和论坛?
  • 有什么问题?

二面感觉自己表现一般般,聊了63分钟,也不知道自己有没有过,不过全程和面试官的讨论很多,有些问题回答的不够好面试官会给我提出建议。很幸运,两天后的晚上接到了电话,因为那天是星期天所以很意外。那个时候刚好在路边散步,突然接到电话一脸懵逼,脑子一热就直接在路边找个地方开干了......

三面

  • 自我介绍
  • 项目中你对数据库做了什么优化?
  • 对数据分库分表了吗?用什么算法进行分库分表。。。
  • 项目问题......
  • 项目中你是根据什么来进行索引的设计的?
  • 项目中把数据放到HBase上面,你rowkey是如何设计让数据均匀分布在RegionServer上的?
  • 一次请求的速度大概是多少?有考虑到做其它的优化吗?(缓存)
  • 说一下索引的原理
  • 知道MySQL插入和查询分别用的是什么锁吗?
  • 知道悲观锁吗?了解多少?
  • 对并发的知识了解多少?
  • 说一下synchronized的优点和缺点,与lock进行比较
  • 说一下ReetrantLock的内部实现
  • 对多线程这一块了解多吗?(我说了解一点,不是很多)他说:那好那问点别的
  • 说一下ArrayList和LinkedList的区别
  • 为什么ArrayList的查询时间复杂度为O(1)?为什么数组查询可以到O(1)?
  • 说一下你对HashMap的理解?说完......put操作的流程大概是怎样的呢?
  • 现在有一亿条数据,要求你利用HashMap对数据进行去重并排序,你会怎么做?
  • 多线程这一块你真的不了解吗?(???他想干嘛,然后我把我知道的说了出来,包括实现的几种方式,线程池这些)
  • 线程池当队列中的任务都执行完毕之后会对线程进行怎样的操作?
  • 多线程是不是肯定比单线程好?
  • 什么样的任务适合用多线程什么适合单线程?
  • 单CPU的情况下适合用多线程吗?
  • 我看你里面很多奖项,挑一个跟我讲一讲吧
  • 有什么问题吗?

结果在路边站了78分钟,面完喉咙都哑了,心脏跳得贼快,刚开始因为紧张讲话支支吾吾,后面就好一些了。整个过程感觉这个面试官问的很仔细,对项目的细节问的很深,自己感觉也是一般般,就是那种好像可以过又好像不可以过的感觉......

两天后,hr打电话来了......约视频面试

本以为技术面已经结束了,结果是自己想多了。视频面是技术专家大佬和hr小姐姐两个人一起面试

技术专家面

主要是针对项目然后提出一些开放性的问题让你提出解决思路

技术专家:

  • 你在工作室项目中的主要工作?
  • 项目的架构是怎样的?
  • 如果现在让你在广州市投放出租车,你觉得出租车的数量会由什么因素来决定?
  • 设计一个打车算法
  • 讲一下数据库索引的原理
  • 数据分表你是按照什么来划分的?有用到什么中间件吗?
  • 快排的实现原理是什么?
  • 了解堆排序吗,为什么堆排序的空间复杂度是O(1)?

hr面

  • 刚才的交流过程中有些东西可能你没有完全给我们展示出来,现在给你一点时间再让我们多了解你一点
  • 你平时有什么爱好吗?
  • 你平时的生活情况是怎样的?你和团队中的人是如何相处的?
  • 你平时是通过什么方式学习的?
  • 你觉得自己遇到最有挑战性的事情是什么?
  • 你希望你未来想要加入的团队是怎样的?
  • 有什么问题要问的?

加起来一共面试了45分钟吧,看到专家大佬超级紧张。面完之后心里松了一口气,终于熬到最后了~ 可是,还没结束T-T,hr小姐姐和我说,如果你这次通过了,后面会有另一个部门的成员来面试你(也就是交叉面),我表面笑嘻嘻说好,心里咯噔一下。

那天下午接到了电话,约我交叉面的时间

交叉面

  • 自我介绍
  • 解释一下并行和并发的区别
  • 如果我要让10个线程并发同时开始运行,你要怎么做?
  • 你认为数据库索引的设计需要考虑什么因素?
  • 知道索引的最左原则吗?解释一下
  • 现在有a b 作为联合索引,有一条sql语句 where b > 0 and a = 7 和 where a>0 and b = 7分别会用到索引吗?
  • 线程池使用时核心线程数和最大线程数的设计要考虑什么因素?
  • 另一个项目)你主要负责哪个部分,难点是什么?
  • 并发下单的并发是在哪个部分?你通过什么来防止超卖这种情况?
  • 如果是分布式情况下你如何防止超卖的情况?
  • 出租车项目的分库分表是按照什么条件进行的?
  • 如果让你设计一个叫车算法,你会考虑什么?如何设计?
  • geohash是什么,你能说一下吗?
  • 如何计算两个geohash块之间的距离?
  • 有什么问题要问的?

交叉面感觉比较难,面到后面有点自闭,觉得自己答得不好超级害怕。面了45分钟也结束了。感觉不好

不过还好上天眷顾了我,三天后,我很幸运收到了录用意向书。


分享一波我在复习过程中刷的题(含详细答案解析)和一些学习资料,都已整理成PDF文档或者Word文档,有需要的朋友可以转发+私信关键词【面试】免费领取~

(1)最新java架构专题系列面试真题+解析(包含Kafka、Mysql、Tomcat、Docker、Spring、MyBatis、Nginx、Netty、Dubbo、Redis、Netty、Spring cloud、分布式、高并发、性能调优、微服务...)

阿里天猫团队5面Java面经:索引+高并发+分库分表+线程池

评论留言+转发文章+关注我后私信回复【面试】即可免费获取我这样一份文档资料!

阿里天猫团队5面Java面经:索引+高并发+分库分表+线程池

阿里天猫团队5面Java面经:索引+高并发+分库分表+线程池

评论留言+转发文章+关注我后私信回复【面试】即可免费获取我这样一份文档资料!


分享到:


相關文章: