龙空技术网

字节半天*3面/5天拿offer,全凭自身硬实力和这份Java面试笔记

马士兵教育 770

前言:

当前兄弟们对“javabyte合并”都比较珍视,大家都想要了解一些“javabyte合并”的相关内容。那么小编也在网摘上网罗了一些关于“javabyte合并””的相关内容,希望你们能喜欢,小伙伴们快快来了解一下吧!

先说说大致情况把,当时是下午两点约的一面,没想到直接面到六点一次性面完了。。。

面试部门:北京的基础架构,后端开发

一面:

讲一讲hash表hash冲突了怎么办?(拉链)除了拉链还有吗?(开放地址法,不是很了解,听过)如果使用hash进行分布式存储有什么弊端?(可扩展性不强,例如增加节点和节点宕机的情况)如何解决?(一致性hash,提到了redis的哈希槽)讲一讲吧一致性hash会出现什么问题?(数据倾斜问题)如何解决?(虚拟节点)介绍JVM(五大部分)什么时候会GC?(答GC过程)你说的MajorGC和fullGC有什么区别?FullGC会有什么问题吗?(STW)什么时候会STW(介绍CMS大致过程,在标记的时候)TCP和UDP区别2MSL是什么?为什么等2MSL?(补充说明等待的时候收到报文会如何处理)你知道什么时候TCP会发送rset报文吗?(不知道)hashMap介绍一下hashMap是线程安全的吗?(不是)如何保证线程安全?(答concurrtenHashMap)让你自己来实现呢?(使用sy加锁)怎么加锁(锁住put和get方法)具体一点(sy分为类锁和对象锁)那你觉得应该加什么锁(对象锁,解释一下)concurrtenHashMap介绍一下(主动说的)CAS讲一讲sy和lock的区别CAS,sy,lock三者应该分别在什么场景下使用?(这个回答得不是很好,我说要看业务需求,三个偏向特点不同,简单介绍三者不同的倾向特点)内存泄露是什么意思?什么时候会出现内存泄露?(静态常量不使用,threadLocal)还有吗?(不知道)算法题:

1)输入一个cd命令:

/hist/add/camera/../int/has/../init 输出最终的文件目录

2)现在有一百万条定时任务,是一个二元组<key,value>,key代表触发的时间,value代表任务。将这一百万条定时任务插入一个调度系统,设计这个调度系统的存储结构,保证两点:插入的速度快,同时保证调度系统可以实现秒级的任务调度

二面:

记得不是很清楚,少了部分

jvm中内存是不需要自己分配的,不像c++需要malloc和free,那你知道window下磁盘是如何管理的吗?(不知道)那你知道磁盘上是如何快速计算当前的容量的吗?(可以设计一个变量,每次存进去加size,释放就减)你可能对这方面不太了解,其实你可以了解一下,里面是用块存储的,可以用bitmap快速计算容量(我提问:那也会有内存碎片吧)肯定会有,这就是为什么window下会定时进行内存碎片的清除,你可以去了解一下xxx(嗯嗯)你知道一个linux代码文件是如何被加载到cpu上运行的吗?(不了解,我说我可以讲讲java的代码是如何被加载运行的)那你讲讲吧你了解协议模型吗?(TCP四层,OIS七层,我介绍五层吧,直接讲输入url到显示界面的过程,详细讲了DNS的递归查询和迭代查询)一个域名是可能支持多个服务的,这个怎么办?(http1.1支持host域)那在高并发的情况下,哪些服务器如何保证dns解析的高效性(缓存)还有其他的吗?(分布式缓存)面试官笑了笑(我解释到,要不然就是从代码上解决,要不然就是从机器数量上解决)TCP和UDP的区别DNS用的是什么协议Ping命令了解吗?发送的是什么报文?(我说我只了解用的是ICMP协议,但是具体不知道)IO模型了解吗?(BIO,NIO,AIO)一个数据从网卡到磁盘的过程进程和线程的区别(提到了协程)为什么协程切换比线程快(不涉及特权模式切换)为什么协程不涉及(应该是一般只用协程做用户态的事情吧,我对go不是很了解)有1000个文件,找出出现次数最大的十个词算法:合并有序链表看我做过论文查重系统,问我核心是什么(本科毕设,分句算法和查重算法,用的编辑距离)能讲一讲编辑距离吗?你当时是自己写的还是用的别人的(用的pyhton包),那你能写一个吗?写个大概思路。(正好之前练过,有小瑕疵,没让跑,整体代码基本正确)看你用过k8s,了解deployment啥啥啥的吗?(不了解,我只是写过yaml文件部署,我可以介绍一下k8s组件,介绍了五六个组件和功能,还讲了我们之前做的负载均衡和高可用)

最后就是给我讲讲说有空可以来实习,问我要不要继续三面,还是改天,因为已经连续两面了,我说继续吧

三面:

自我介绍,开始讨论项目,终于聊我的项目了。。。数据从磁盘到程序的过程(不满意)我又提到了Kafka的零拷贝(觉得有问题)问我协议模型(五层)三次握手四次挥手(八股文)为什么是三次?为什么是四次?(感觉不满意,和他讨论了很久)面试官认为一般是对称的,如果不对称一定是某个环节combine了(我说我回去再看看)linux内存管理了解吗?怎么管理的?(其实我是不知道的,但是二面面试官正好告诉我了块式存储,所以我说了块式,然后还说了段页式)他说段页式应该是很古老的吧现在让你自己设计一个内存管理,你怎么设计(这个地方讨论了很久,我每次有新的想法就会有问题抛出来,然后我再想。。。)最后有一个稍微觉得可以的了,说你这个设计算比较雏形的了(主要是问一个大内存怎么申请,快速查找可用空间,内存碎片怎么最少)讲一讲JVM吧hashmap后面记不清了,后面就是偏八股文了

这里给大家推荐一份我面试之前看的java面试笔记:

这份资料包含了很多当下热门的java知识点,需要获取的小伙伴可以直接转发+关注后私信(学习)即可免费获取!

不多展示了,你想要的它都有,

反问:

我说我想最后补充两点,算是表现一下我的优势吧:我知道可能今天表现不是很好

1)我学习能力很强,简历上很多奖学金都是我自己拿的2)开发能力强,抗压能力强,百度实习期间每天工作超过十二个小时3)我对内存这方面的确是不了解,我也不解释,但是我有我擅长的领域,例如我对java比较了解

最后他说了一句,其实还ok了,然后就没了,以为凉了,第二天hr说过了

总体来说其实不是特别难,我觉得提前批比秋招简单。。

标签: #javabyte合并