一面
一面都是聊项目,聊了半个小时,主要包括这几个问题:
- 项目介绍
- 项目中如何对数据库进行优化
- 项目中的难点
- 你在项目中充当的角色
和面试官聊了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、分布式、高并发、性能调优、微服务...)
评论留言+转发文章+关注我后私信回复【面试】即可免费获取我这样一份文档资料!
评论留言+转发文章+关注我后私信回复【面试】即可免费获取我这样一份文档资料!
閱讀更多 Java互聯網架構I 的文章