写点什么

简历被拒?看我如何在一年之内吃下今日头条 offer

用户头像
马小轩
关注
发布于: 12 小时前

 一、准备面试

其实从三月份投递简历开始准备面试到四月份收 offer,也不过 1 个月的时间,但这都是建立在我过去一年的积累啊,无数次的通宵自习室,图书馆的专属椅子都被我坐的陷进去。避免误导大家,这次也不做标题党,写了准备一年,踏踏实实干事。



都是比较不错的书单

以下是我去年给自己订的学习计划:

一月:

大数据入门

整个一月份都在刷入门视频和《Hadoop 权威指南》,又临近期末,每天 5 点半起床,看两个小时的视频然后上课或者复习期末考。

二月:

  1. 剑指 offer 刷一遍、数据结构、JavaSE、JVM、多线程

  2. 剑指 offer 有些搞不懂的直接跳过,等下个月第二遍再刷;

  3. 数据结构重点是各种树、二叉树、红黑树的一些特性以及链表的特性;

  4. JavaSE 主要是类对象接口的区别,能不能继承,Static 的特点,各种 Hashmap,ArrayList 等集合框架的原理源码;

  5. JVM 是根据网上整合的高频面试题进行学习的,刷了一遍面试题之后才去看周志华的《深入理解 Java 虚拟机》,JVM 难的不是 JVM 布局,垃圾回收算法等这些理论,而是结合代码和项目场景。比如说一段代码,有很多个类、方法,其中又有静态类和全局变量,这时候项目跑起来的时候哪些先加载,哪些变量存放在哪个区,不止要懂理论,还要结合代码懂理论。还有就是项目中的 OOM,栈溢出,JVM 的参数调优等等。

  6. 多线程也是刷网上面试题和博客的,几本多线程的书都是一坨一坨的,理解不来。先动手把几个多线程实现方法实现了一遍,然后分析优缺点,再由此切进去线程不安全和各种锁。多线程学习不同 JVM,自己多动手,多调试一下,控制台都会告诉你答案。

三月:

剑指 offer 二刷,数据库、操作系统、网络、准备面试

  1. 剑指 offer 第二遍重点刷第一遍时思路懂代码不懂的。

  2. 数据库刷了牛客网 SQL 实战 100 多题的,其他都是索引原理,悲观乐观锁等理论。

  3. 操作系统刷高频面试题。死锁的产生条件、解决方法等等,资源调度算法,并发和并行等。

  4. 网络也是刷面试题。三次握手四次挥手以及为什么要这样做、TCP 和 UDP、网页请求过程、DNS 解析过程、网络模型、响应码的意思等。

  5. 我每刷一道算法或者理解了一道面试题都会进行整理,所以到面试之前看看整理的文档和博客就行,异常轻松。这个月也继续投递简历进行面试,从三月份开始都是边投边准备,不存在全部准备好再去投。

三月份收了京东、瓜子二手车等二线大厂的 offer。

四月:

大数据项目、手写剑指 offer、继续面试

  1. 三月份被阿里菜鸟部门的三面面试官怼了一发,说简历没有大数据项目面大数据岗,理论会再多有什么用,于是打算在四月份补一下项目。

  2. 在补项目的同时,不忘算法,练习白板写代码。

四月份收了腾讯、去哪儿一些 offer,腾讯和去哪儿终面都得现场面,所以一天飞北京,一天飞深圳。拿到腾讯 offer 的时候跟 HR 商量能不能去上海或者北京的 base,HR 说不行,于是就没去了。选工作和生活城市有一个硬性标准:离家远!那些在北方读书的同学毕业之后一直要往家里跑,而我则是一直往外跳,或许是因为在厦门待了四年吧,家乡也是「围城」啊。

5-12 月:

实习,看框架源码,面试,整理面经

最后选择了去 Kyligence 实习了,刚好趁这个机会学习了 Kylin 源码,看了 Hadoop 和 Spark 的部分源码。后面的面试也是为了倒逼自己学习,在面试中找不足,也顺便整理了一些面试资料。

总结:

一定要列好自己的学习计划,也要学会根据自己的学习情况调整计划。项目是面试的敲门砖,也是面试的大头,我是从大二出去实习的,所以在项目这边可以花较少的时间,不用从零开始学。底层理论一定要会,不然大厂无望。算法一定要硬刚,总共就那几种题型,我刚开始也很抵触的,觉得太难了,后面迎难而上也就那么回事。第一遍不行就第二遍,不然就第三遍,直到现在剑指 offer 里面也有一些我不懂的题目,但我也不会去深究,大局为重,不抠细节。



别的同学放寒假的时候,自己一个人在学校旁边租了个小房子学到过年前夕;为了巩固实习的项目更好地面试,跑了几次之前实习的公司请同事吃饭问项目细节;为了阿里面试用肝硬刚,连夜复习;简历投的太多,信息都被卖了,而且一听到手机响就以为是面试电话;去腾讯终面,在深大的通宵自习室连夜复习。

以上是我过去一年的准备,说说我从投递简历到收 offer 这一个月的准备。

1.复习算法。把以前刷过的算法题分类整理了一下,因为之前有整理过,所以复习起来没用多少时间,还特意去理解了长长的 KMP 算法,LRU 算法。

2.复习理论基础。除了复习整理的面经和资料之外,还特意去了解了一下 Golang,因为头条用的 go 语言。

3.特意准备了几个项目技术难点,能在面试的时候炫一下。



二、头条一面(Java+项目)

  1. 倒排索引

  2. 讲讲 redis 里面的哈希表?

  3. happen-before 的规则?

  4. volatile 修饰符,synchronize 锁

  5. java 单例模式的实现,懒汉、饿汉?

  6. 进程与线程的区别,多进程和多线程的区别?

  7. HashMap 原理,为什么用红黑树,红黑树的特点?

  8. 快排时间空间复杂度,最好最坏的情况,优化方案?

  9. TCP 的拥塞控制,具体过程是怎么样的?UDP 有拥塞控制吗?如何解决?

  10. 讲讲了解的垃圾回收算法和回收器,什么时候执行 STOP THE WORLD?

  11. 了解 Go 语言吗?

三、头条二面(大数据+项目)

  1. Kylin 的项目架构

  2. Paxos 和 ZAB 协议

  3. CAP 理论,分区容错性的意义

  4. 大表 Join 小表优化,如何处理数据倾斜?

  5. 讲一下最大堆和最小堆

  6. HDFS 的读取、写入,容错处理。(源码)

  7. MapReduce 的过程(第一版和第二版的)

  8. MR shuffle,Spark shuffle。

  9. namenode HA,脑裂,Yarn 的调度机制。

  10. Hive 的内部表和外部表区别、数仓建模模型、数仓分层、雪花模型和星型模型。

  11. 了解 ClickHouse 吗?它与 Kylin 的区别?

四、头条三面(算法+场景题)

  1. LRU 算法实现(伪代码)

  2. 链表倒数第 K 个数(讲思路)

  3. 一堆螺丝和螺母用最短时间匹配(代码实现)

  4. 求每天浏览页面的新用户(Hive QL 实现)

  5. 求抖音小视频每日点击量最高的 10 个(Hash + 最大堆)



五、如何通过头条笔试?

这次的笔试里总共有 5 道,我 AC 了 2.5 题,第一题 90%,第二题 90%,第三题 70%,不算好,但勉强通过了。去年的这个时候我可是连题目都看不懂的,看得懂的只知道用嘴怎么说,不会用代码实现。通过这段时间的算法训练,总结了如下几点算法笔试经验:

1.平时刷题一定要总结归纳,最好分类。比如关于树的题型,链表的,数组等等,观察它们的解题思路,总结出解题套路。

2.积累工具类算法。什么叫工具类算法?就是你解一道算法题需要用到另一种算法,这个被调用的算法就是解决这道算法题的工具。比如常见的「深度优先遍历」、「广度优先遍历」、「01 背包」、「KMP 算法」以及常见的选择和排序算法都是经常使用的工具类算法。

3.学会抽象题目。笔试算法题不同于面试算法,不会直白跟你说要使用哪种算法去解答,更多的要自己学会抽象,抛开题目本身,要明白内部讲的是什么,别被题目的糖衣炮弹迷惑了。只有把题目抽象成最原始的算法你才能更好地使用工具类算法进行解答。

六、如何准备头条面试?

头条面试和其他大厂可能大同小异,但就是这个小异才是关键地方,能异于其他人的地方。可以从如下几个方面去做准备:

1.特意准备几个面试题源码。像我在回答一些中规中矩面试题的时候,都会从源码角度出发。比如常见的 HashMap 等集合类,多线程的各种锁以及大数据框架的部分源码。

2.特意准备项目难点。面一些大厂的时候避免不了被问到项目难点,不可能用普通 Bug 含糊过去啊。这边可以从项目用到的技术栈出发,去寻找技术栈在项目中会存在的难点,然后套进自己的项目,找个自己能懂,最好能全懂的。

3.针对性去了解公司的技术栈使用情况。比如头条使用 Go,众人皆知,那为什么我不突击学习一下呢?比如从业内人士得知头条最早使用的是 Kylin 框架,后面慢慢转为 ClickHouse,那我必须了解一下两者的不同啊,而且可以结合头条的业务场景。

七、一个关于如何进大厂的小建议

我一直崇尚「曲线救国」的做法,也一直在向别人传播这种做法。现在能力背景不足没关系,只要规划好自己的学习路线,一步步阶梯式往上爬,总可以实现目标。因为我自己二本出身,但我意识的早,大二就开始实习,用项目和实习经历弥补我背景不足,然后一步步走到「offer 自由」。很多时候并不是只有巨人才可以成功,你只需要做到行动上的普通人,就可以超过很多思想上的巨人,行动上的矮子。

读者福利

同时我自己也总结出了互联网公司 java 程序员面试涉及到的绝大部分面试题及答案做成了文档和架构视频资料免费分享给大家(包括 Dubbo、Redis、Netty、zookeeper、Spring cloud、分布式、高并发等架构技术资料),希望能帮助到您面试前的复习且找到一个好的工作,也节省大家在网上搜索资料的时间来学习。

面试文件获取方式:

需要获取资料文档的朋友 可以关注+转发后点击这里免费领取

合理利用自己每一分每一秒的时间来学习提升自己,不要再用"没有时间“来掩饰自己思想上的懒惰!趁年轻,使劲拼,给未来的自己一个交代!






用户头像

马小轩

关注

还未添加个人签名 2021.06.25 加入

还未添加个人简介

评论

发布
暂无评论
简历被拒?看我如何在一年之内吃下今日头条offer