从字节跳动面试中快速胜出:五天三面,这份Java面试笔记功不可没

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

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

7636d6fc0b870b0a34f94a98299507ea.jpeg

一面:


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

1)输入一个cd命令:
/hist/add/camera/../int/has/../init 输出最终的文件目录

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


二面:


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

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

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


三面:


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

后面记不清了,后面就是偏八股文了

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

999ef9432ac5be0eaf65fbf4bc50b5a5.jpeg

这份资料包含了很多当下热门的java知识点,需要获取的小伙伴可以跳转文章末尾获取

08aa4cc6b69007a9e1242dbd1b6d50a7.jpeg 78f9229dbe76de57400a870cb3f9e398.jpeg 2c8b547ff8c3c50ae75d8a0e1cffd6a7.jpeg

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

反问:

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

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

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

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

需要完整版PDF学习资源请扫描下方名片100%获取免费下载方式!

👇👇点击下方名片👇👇

  • 27
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值