写在开篇

和往年相比,今年的秋招看上去不是那么顺利,但是令我惊讶的是第一家给我面试机会的公司竟然是宇宙条。一开始接到面试通知时,心情特别复杂,紧张又兴奋,字节跳动是出了名的考算法,实际上我算法部分是相对薄弱的。这次面试,一共三轮,共计四个小时左右,这三轮面试对我来说,简直是灵魂拷问,至于结局,往下看吧!

字节跳动,三轮面试,四个小时,灵魂拷问,结局我哭了但下次还敢!

第一轮面试:1小时28分钟

  • 自我介绍

  • 数据库索引的作用是什么?

  • 段页式

  • 虚拟内存

  • 缺页中断

  • Major/Minor page fault区别

  • TLB作用

  • 进程/线程和虚拟内存的关系

  • x86相关 没听清 直接说不会

  • 讲讲jvm,内存泄漏怎么理解的

  • 垃圾回收机制,垃圾回收算法讲解一下,怎么判断是老年代,触发垃圾回收的时机在什么时候?

  • BIO、NIO、AIO

  • select poll epoll

  • RMQ算法

  • 无锁队列实现细节

  • 数据库ACID

  • 实验室项目

  • vector底层 为什么扩容是1.5倍

  • 算法部分:

(1)给一个正整数,判断是否是2的n次幂,他说用最快的方式不要递归? 肯定是运算的方式,你能想到的数的运算有哪些,除了加减乘除? 这个地方讲了很多,运算太多了,但是感觉不是面试官想要的,我最后把二进制的移位都说了出来,才get到他的点,问还有些什么,他最后问我怎么没提异或,并且出了几个二进制数让我异或算结果

(2)给一个数组,数组里面有rgb三种数,数量和顺序完全无序,给一个算法按照他想要的r都在前面,g都在中间,b都在后面,用移动次数最少的算法进行计算,写算法 这个地方一直叫我优化再优化,我快疯了,我说我不行要放弃了,他说你简历不是写着强烈的好奇心求知欲嘛,没事再想想,我直接笑喷了才放松了点继续想,这简直是心理战

第二轮面试:1小时11分钟

  • 自我介绍

  • 问我计算机网络,操作系统,组成原理,数据结构哪个学的最好?我说计网,因为我实习的时候看了很多计网相关的东西,他叫我把自己最熟悉的东西详细讲解出来

  • 使用https就能保证数据安全吗?

  • http协议处于网络模型哪一层

  • tcp和udp的本质区别是什么?这个地方在数据可靠性深挖的比较多

  • 实习过程中用http协议做的事情,http状态码解释

  • http发起请求的时候,get,post别的还有些啥

  • 用post获取数据会有什么问题吗?get和post的区别有哪些

  • c和Java的区别,本质区别

  • 面向对象几大特征?什么时候该用继承什么时候不该用继承?有没有遇到过这种使用?为什么继承破坏了封装?

  • 实际项目中运用过多线程吗?用来干什么?

  • 多线程安全问题怎么解决?实际项目中怎么解决的,场景和解决方式

  • 多线程协作方式,除了锁还有什么吗?

  • 信号量解释一下,干什么用的?

  • 死锁怎么产生的?

  • 发生了死锁怎么办?

  • 银行家算法了解么?

  • 算法部分:

(1)有很多纸盒子,每个纸盒里里面套着纸盒子,其中有一个有硬币,怎么把硬币找出来,写算法
(2)树的遍历方法有什么,写一个二叉树前序遍历算法

第三轮面试:1小时15分钟

  • 自我介绍一下

  • 讲一件自己做项目最有挑战的一件事情

  • 比较mysql和mongodb的优劣

  • mysql用join来做连接,mongodb怎么做的

  • mongodb冗余字段的方式和mysql有啥不同,缺点

  • 信息变更了,name变了怎么处理这些冗余字段?

  • mongodb里面的aggravate使用过吗,举一个例子,有什么用

  • pipeline运行机制是什么,假如你来做mongdb执行引擎,自己设计一个方式来设计这个pipeline

  • 这个问题我回答了很久,因为我完全不懂pipeline,硬着头皮设计。

  • 你觉得docker这个技术能解决什么问题?为什么要用docker做部署?有什么好处

  • 运行在docker里面的文件系统,docker怎么实现文件系统机制?

  • 在docker里面根目录cd,能不能跳出沙箱回到宿主机?

  • 问了下我前端知识了解的程度?react 和 jquery有什么区别?

  • 直接上算法了

(1)寻找最近的父节点,给了两个例子,差不多leetcode中等难度

(2)开放性的问题,猫抓老鼠,猫在圆型中间,老鼠在圆的周长上,速度相同,问猫能不能抓到老鼠,这个问题我给的回答他不是很满意,我把关键点说到了但是不能用数学解释出来

结局

结局当然是凉了,没有第四面的通知,但这次经历给我的感受还是很不一样的,也为我下一场面试积攒了经验。之后打算再投几家互联网一线大厂,希望能够顺顺利利, 收到好消息吧。

我是如何备战字节跳动面试的?

领取一下Java文档点击此处绿色传送门

第一步:准备简历

准备简历,并不是指可以在网络上下载一份简历模板,然后修修改改就可以使用了。简历的精心准备,需要注意三个要点:(1)注意区分:了解,熟悉,精通,不要乱写,面试官很多问题都是根据简历描述来进行的;(2)专业知识和项目经验在精不在多,尤其是项目经验一定要写自己熟悉的且有内容可说的,不要认为写得越多越好。(3)要熟悉自己的简历内容,准确掌握,最好是多阅读自己的简历。

如果还是不知道怎么准备自己的简历,我这边可以分享一下我搜集到的简历模板,给大家一个参考,希望能够在给大家一个合格的敲门砖。



第二步:复习+总结

离面试期越来越近也越来越焦虑,这个时候更需要去调整好自己的心态,沉入到复习当中,对各个知识点要学会查漏补缺,学着多去做做总结。

关于复习和总结,我自己也整理了不少资料,均是我的收获,有需要的也可以进行分享。

如:






第三步:刷题

Java筑基系列:Tomcat+Mysql+设计模式+并发+Netty+JVM

开源框架系列:Spring+SpringMVC+MyBatis

微服务架构:Dubbo+SpringBoot+SpringCloud

分布式数据库系列:Memcached+Redis+MongoDB

分布式通讯系列:ActiveMQ+RabbitMQ+Kafka

分布式限流系统:Nginx+zookeeper

一线互联网大厂历年真题系列

算法宝典


总结

无论是哪家公司,都很重视基础,尤其是对于应届生来说,所以在面试前基础一定要打扎实。面试是一个双向选择的过程,不要抱着畏惧的心态去面试,不利于自己的发挥。同时看中的应该不止薪资,还要看你是不是真的喜欢这家公司,是不是能真的得到锻炼。其实我写了这么多,只是我自己的总结,并不一定适用于所有人,相信经过一些面试,大家都会有这些感触。