前言
字节跳动面试算法那是行业出了名的厉害。人狠话不多,上来就是一套算法“组合拳”,如果你不“抗揍”的话,连面试的机会都没有了。
面试字节跳动,拼多多这种大厂肯定躲避不了算法题的,相信面试过的小伙伴都知道,不管在现场面还是视频面肯定都会被问到算法,难度是要比笔试的时候容易些的。
不多扯,如果你是应届毕业生、学了一年多Java的知识或者是工作多年想回顾复习算法,我想你应该具备这些知识。这篇文档内容我花了一个多星期的时间来详解描述,经过不断的修改最终整理出这份精美的PDF。
字节跳动技术一面
面问的都还比较基础,答得也还算顺利
- 说下你的实习项目吧
- 讲一下线程参数的含义
- Innodb的索引实现
- 为什么是B+树?
- Redis的使用,分布式锁的实现
- 操作系统虚拟内存换页的过程
- TCP三次握手
- volatile关键字的作用
- 乐观锁、悲观锁
- HashMap结构,是否线程安全?ConcurrentHashMap如何保证线程安全?
- 之前用过哪些设计模式?
- 算法题:滑动窗口
字节跳动技术二面
发现字节的面试官都挺年轻的,头发也没怎么秃,哈哈~
- 说一下B树和B+树的区别
- 说一下HashMap的实现,扩容机制,扩容时如何保证可操作?
- Redis扩容机制(渐进式单线程扩容)
- Spring AOP的原理
- Spring IoC的原理,如何实现,如何解决循环依赖?
- 两线程对变量i进行加1操作,结果如何?为什么?怎么解决?
- CAS概念、原子类实现原理
- synchronize底层实现,如何实现Lock?
- AQS有什么特点?
- 手写项目中某个模块代码。
- 介绍各种网络协议。
- DNS在网络层用哪个协议,为什么。
- 介绍HTTPS协议,详述SSL建立连接过程。
- 代码题:反转单链表。
- 代码题:复杂链表复制。
- 代码题:数组a,先单调地址再单调递减,输出数组中不同元素个数。要求:O(1)空间复杂度,不能改变原数组
字节跳动技术三面
算法题多到爆炸,感觉是算法专场,宇宙条果真名不虚传
- 说一下Java垃圾回收机制
- 64匹马,8个赛道,找最快的4匹马。
- 64匹马,8个赛道,找最快的8匹马。
- 给出两个升序数组A、B和长度m、n,求第k个大的
- 给出数组A,长度为n,数组中元素的值位于[0, n - 1]之间,求是否有重复元素
- 讲一下多线程与多进程区别
- JVM中什么时候会进行垃圾回收?什么样的对象是可以回收的?
- Spring主要思想是什么?
- 你未来的发展方向是什么?确定了么?打算一直做Java?有考虑过转吗?
- 那你平时是怎么学习Java的呢?
- 分享最近看的一本书
字节跳动技术四面
那天状态不佳,面试官也没有问太多问题,以为没戏了
- 场景题目:设计一个短域名服务:短信存不了太长网站,需要弄成短域名,你该如何设计一个服务,可以为全国的网址服务。
- TCP为什么是三次握手四次挥手?
- 数据库的隔离级别
- sql题,写了个连表查询外加模糊查询
- 算法:镜像二叉树 …
字节跳动HR面
再次感叹一下,字节跳动的小姐姐又漂亮又年轻!
- 自我介绍
- 你了解字节跳动吗?说说你眼中的字节吧!
- 你平时用字节跳动的哪个产品比较多?
- 为什么想要来字节?意向城市是北京吗?
- 说一下你自己的职业规划吧
- 预期薪资
- 其他一些常规问题
最后的话
无论是哪家公司,都很重视Spring框架技术,重视基础,所以千万别小看任何知识。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。
同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,好了希望这篇文章对大家有帮助!
部分截图:
时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,好了希望这篇文章对大家有帮助!**
部分截图:
[外链图片转存中…(img-GNeyoKuc-1651294267631)]