前言
一般的小项目,比如几百人左右访问的项目,访问量几万的项目,如果想用缓存,单机实例完全够用。小黄图就是用的阿里云256MB
配置的Redis
缓存,日几千的访问量是妥妥够用的了。Redis
号称可以支撑10w+qps
,当然这也给机器配置有一定的关系,如果单实例满足不了需求,想追求更高的性能和稳定性,可以选择主从、哨兵已经更好的解决方案Redis-Cluster
集群。
[](()拼多多(三面)
==========================================================================
面试前
面完蚂蚁后,早就听闻拼多多这个独角兽,决定也去面一把。首先我在脉脉找了一个拼多多的HR,加了微信聊了下,发了简历便开始我的拼多多面试之旅。这里要非常感谢拼多多HR小姐姐,从面试内推到offer确认一直都在帮我,人真的很nice。
一面
-
为啥蚂蚁只待了三个月?没转正?
-
Java中的HashMap、TreeMap解释下?
-
TreeMap查询写入的时间复杂度多少?
-
HashMap多线程有什么问题?
-
CAS和synchronize有什么区别?都用synchronize不行么?
-
如果要保证线程安全怎么办?(ConcurrentHashMap)
-
ConcurrentHashMap怎么实现线程安全的?
-
get需要加锁么,为什么?
-
volatile的作用是什么?
-
底层怎么实现的?
-
在多核CPU下,可见性怎么保证?
-
聊项目,系统之间是怎么交互的?
-
系统并发多少,怎么优化?
-
给我一张纸,画了一个九方格,都填了数字,给一个MN矩阵,从1开始逆时针打印这MN个数,要求时间复杂度尽可能低
-
可以先说下你的思路(想起来了,说了什么时候要变换方向的条件,向右、向下、向左、向上,依此循环)
-
有什么想问我的?
二面
-
自我介绍下
-
手上还有其他offer么?
-
部门组织结构是怎样的?
-
系统有哪些模块,每个模块用了哪些技术,数据怎么流转的?
-
链路追踪的信息是怎么传递的?
-
SpanId怎么保证唯一性?
-
RpcContext是在什么维度传递的?
-
Dubbo的远程调用怎么实现的?
-
Spring的单例是怎么实现的?
-
为什么要单独实现一个服务治理框架?
-
谁主导的?内部还在使用么?
-
逆向有想过怎么做成通用么?
-
有什么想问的么?
三面
二面老大面完后就直接HR面了,主要问了些职业发展、是否有其他offer、以及入职意向等问题,顺便说了下公司的福利待遇等,都比较常规啦。不过要说的是手上有其他offer或者大厂经历会有一定加分。
小结
拼多多的面试流程就简单许多,毕竟是一个成立三年多的公司。面试难度中规中矩,只要基础扎实应该不是问题。但不得不说工作强度很大,开始面试前HR就提前和我确认能否接受这样强度的工作,想来的老铁还是要做好准备
字节跳动
面试前
头条的面试是三家里最专业的,每次面试前有专门的HR和你约时间,确定OK后再进行面试。每次都是通过视频面试,因为都是之前都是电话面或现场面,所以视频面试还是有点不自然。也有人觉得视频面试体验很赞,当然萝卜青菜各有所爱。最坑的二面的时候对方面试官的网络老是掉线,最后很冤枉的挂了(当然有一些点答得不好也是原因之一)。所以还是有点遗憾的。
一面
-
先自我介绍下
-
聊项目,逆向系统是什么意思
-
聊项目,逆向系统用了哪些技术
-
线程池的线程数怎么确定?
-
如果是IO操作为主怎么确定?
-
如果计算型操作又怎么确定?
-
Redis熟悉么,了解哪些数据结构?
-
跳表的查询过程是怎么样的,查询和插入的时间复杂度?
-
红黑树了解么,时间复杂度?
-
既然两个数据结构时间复杂度都是O(logN),zset为什么不用红黑树
-
点了点头,说下Dubbo的原理?
-
CAS了解么?
-
那我们做一道题吧,数组A,2*n个元素,n个奇数、n个偶数,设计一个算法,使得数组奇数下标位置放置的都是奇数,偶数下标位置放置的都是偶数
-
先说下你的思路
-
下一个奇数?怎么找?
-
有思路么?
-
你这样时间复杂度有点高,如果要求O(N)要怎么做
-
时间差不多了,先到这吧。你有什么想问我的?
二面
-
面试官和蔼很多,你先介绍下自己吧
-
你对服务治理怎么理解的?
-
项目中的限流怎么实现的?
-
具体怎么实现的?
-
如果突然很多线程同时请求令牌,有什么问题?
-
怎么解决呢?
-
如果不用消息队列怎么解决?
-
分布式追踪的上下文是怎么存储和传递的?
-
Dubbo的RpcContext是怎么传递的?
-
你说的内存泄漏具体是怎么产生的?
-
线程池的线程是不是必须手动remove才可以回收value?
-
那你说的内存泄漏是指主线程还是线程池?
-
可是主线程不是都退出了,引用的对象不应该会主动回收么?
-
那你说下SpringMVC不同用户登录的信息怎么保证线程安全的?
-
这个直接用ThreadLocal不就可以么,你见过SpringMVC有锁实现的代码么?
-
我们聊聊mysql吧,说下索引结构
-
为什么使用B+树?
-
什么是索引覆盖?
-
Java为什么要设计双亲委派模型?
-
什么时候需要自定义类加载器?
-
我们做一道题吧,手写一个对象池
-
有什么想问我的么?
小结
头条的面试确实很专业,每次面试官会提前给你发一个视频链接,然后准点开始面试,而且考察的点都比较全。
面试官都有一个特点,会抓住一个值得深入的点或者你没说清楚的点深入下去直到你把这个点讲清楚,不然面试官会觉得你并没有真正理解。二面面试官给了我一点建议,研究技术的时候一定要去研究产生的背景,弄明白在什么场景解决什么特定的问题,其实很多技术内部都是相通的。很诚恳,还是很感谢这位面试官大大。
总结
从年前开始面试到头条面完大概一个多月的时间,真的有点身心俱疲的感觉。最后拿到了拼多多、蚂蚁的offer,还是蛮幸运的。头条的面试对我帮助很大,再次感谢面试官对我的诚恳建议,以及拼多多的HR对我的啰嗦的问题详细解答。
这里要说的是面试前要做好两件事:简历和自我介绍,简历要好好回顾下自己做的一些项目,然后挑几个亮点项目。自我介绍基本每轮面试都有,所以最好提前自己练习下,想好要讲哪些东西,分别怎么讲。此外,简历提到的技术一定是自己深入研究过的,没有深入研究也最好找点资料预热下,不打无准备的仗。
这些年看过的书:
《Java核心知识》《Java面试宝典》《高并发与多线程》《Java程序性能优化》、《Spring实战》、《Zookeeper》、《高性能MySQL》、《亿级网站架构核心技术》、《可伸缩服务架构》、《Java编程思想》
说实话这些书很多只看了一部分,我通常会带着问题看书,不然看着看着就睡着了,简直是催眠良药
最后,附一张自己面试前准备的脑图:
面试前一定少不了刷题,为了方便大家复习,我分享一波个人整理的面试大全宝典
想获取个人高清面试准备的可以关注公众号:程序员黑哥 领取及个人也准备了很多面试题含答案的资料提供供你刷!
- Java核心知识整理
Java核心知识
- Spring全家桶(实战系列)
最后
本人也收藏了一份Java面试核心知识点来应付面试,借着这次机会可以送给我的读者朋友们:
目录:
Java面试核心知识点
一共有30个专题,足够读者朋友们应付面试啦,也节省朋友们去到处搜刮资料自己整理的时间!
Java面试核心知识点
385b70f42eaa9bf568358247e.png)
Java核心知识
- Spring全家桶(实战系列)
最后
本人也收藏了一份Java面试核心知识点来应付面试,借着这次机会可以送给我的读者朋友们:
目录:
[外链图片转存中…(img-Ss9LI99r-1649746271374)]
Java面试核心知识点
一共有30个专题,足够读者朋友们应付面试啦,也节省朋友们去到处搜刮资料自己整理的时间!
[外链图片转存中…(img-7IfExksu-1649746271374)]
Java面试核心知识点
阿里P7熬夜整理的《Java全套学习手册》,火爆IT圈