互联网寒冬,一年经验字节跳动、虾皮、快手、拼多多前端面试总结

11,339 阅读16分钟

年中的时候因个人原因,打算离开腾讯,到外面看看,投了若干简历,最终面试了字节跳动、虾皮、快手、拼多多这4家公司。有的喜有的忧,本文是对本次面试的一个总结。

快手

快手是最早约的面试,在boss直聘上投完大概几天就约了。也是我本次第一家面试的公司。时间某个工作日的晚上8点,那天早早溜回家面试了,是在牛客网上进行的

主要问的问题如下:

  • react16新增了哪些生命周期、有什么作用,为什么去掉某些15的生命周期(写过码看过文档都能答上了)

  • fiber怎样的,如何实现异步渲染(链表/可中断)

  • reduxredux-saga的区别和原理

  • 项目中用到的saga-duck是个什么东西

  • useEffect的实现原理(坦白说自己没看过react的实现,就说了下preact的实现)

  • 异步渲染和旧版的diff的区别

  • babel实现转码的过程(词法/语法分析)

  • 项目的技术栈怎么选型(这种问题好几次都被问到,感觉我真的不太知道怎么答)

  • 小程序底层实现原理了解多少(说了下双线程模型/预加载webview

  • 项目nodeJs应用异常退出如何处理(pm2/uncaughtException事件等)、日志上报怎么做(输出重定向到文件,elk服务传传到kibana)

  • graphic schema怎么设计(说了下我对于项目中的理解,资源维度,感觉回答不太好)

  • 有哪些技术驱动业务的案例(说了下这个插件的思路和webpack一些优化)

最后写了一道算法:最大乘积子序列,有正负数的情况。应该对应于这个leetcode题目。这里我理解错题意以为这个序列是可以不连续的,而且对于理解错的题意也用了一种错误的写法,用了o(n2)的一种实现。然后面试官提示说o(n),最后还是没做出来。这个题目其实自己在之前的刷题的时候自己也是比较顺利能解出来了,这里有点可惜,面试临场代码能力还是有待加强

最后面试官大概讲了下部门情况,他们那边是深圳快影前端团队,目前规模还不大,正在大力招人。最后还问了下我如何看待目前部门工程化建设不足的问题,我表示这是一个很好的机会去挑战自己(hhh)。

当时这次面试之前,差不多两年没面试了(上一次面试还是2018年的8月),很多地方自己感觉也是表现不太好。虽然面试官最后说了认为我是一个比较优秀的同学,让我当时迷之自信误以为会有下一轮。过了一周没有任何答复后,去boss直聘上问了下hr,答复说算法有待加强,第一次面试凉凉~

拼多多

拼多多投的是广州的部门,好像是小程序团队,通过一个同学内推的

一面 47分钟。某天晚上9点

  • redux的理念(说了下action dispatch state啥的,单向数据流)

  • react-reduxconnect怎么实现(高阶组件、context注入store、subscribe订阅store数据变化)

  • mixin hoc 继承的区别,优缺点

  • react diff如何实现

  • react 旧版的diff用深度优先还是广度优先。为什么用深度优先,广度优先能实现吗(其实我认为广度也能实现的,面试官问广度有啥不好,我确实不知道..)

  • diff的时间复杂度?为什么?(o(n)。提了下react优化o(n3)->o(n))

  • react-router实现原理(hash/html5 history)

  • 客户端路由hash/history实现的区别、原理

  • 有哪些常见的http

  • websocket/轮询的好处和缺点 (性能、兼容性)

  • websocket的握手过程(urgrade websocket

  • tcp的握手过程

  • tcp/udp的区别

  • 一个应用场景redux触发几次action如何设计(这个问题感觉有点迷,不知道有啥问,我回答也有点迷,面试官说可以了...)

  • 尽可能多实现pdd app导航布局实现(就是类似4等分div并列排布)

  • 如何清除浮动

  • BFC实现原理

  • 开放题:pdd首页假设没有任何优化,尽可能多的想优化的办法(懒加载、打包优化、webpack速度、代码压缩、雪碧图、http2 balabala....)

二面 周日 下午2.30 35分钟

  • css的盒子模型(content-box border-box)

  • 实现动画有哪些方法 (js css)

  • react mixing hoc 继承 hook之间的区别/优缺点

  • 浏览器渲染出一个页面的过程

  • vue/react技术选型

  • 项目相关,项目重构开发如何并行balabala...

  • 项目中工程化进行了哪些优化

  • 项目中继续进行优化会从哪些方面去做(说了下webpack5 module fedration)

  • nodejs项目的性能优化

  • linux文件权限(4 2 1 )

  • 前端监控怎样实现 (数据采集、上报、展示之类)

三面 本来约了去星期天广州现场的,结果车票都买好了,前几天,hr说部门架构调整,岗位暂时不开放了。又凉了~

拼多多的面试时间还是很合适的,周天+晚上9点,基本可以避免上班的尴尬(毕竟11 11 6...)。问的问题也中规中矩吧。不过也无缘了。拼多多的两轮是比较少有的不需要手写代码的,都是电话面试。

虾皮

虾皮通过一个同学内推的,面的金融部门

虾皮都是qq视频面试+腾讯文档word写代码

一面 周二早上

  • http 302 301 307之间的区别

  • 301和302对于seo来说哪个更好 (301)

  • 跨域是什么、如何解决

  • jsonp有什么缺点

  • 图片base64和外链的应用场景,各有什么优缺点(base64减少请求数,但是会增加额外的体积)

  • http缓存机制

  • https的握手过程是怎样的

  • set/map的区别

  • hook的局限性

  • setState和hook的区别

  • decorator的作用,编译后是怎样的(@decorator -> decorator(target)...)

  • symbol是什么,一般用来做什么

  • csrf 是什么 如何防范

  • sql注入是什么,如何防范

  • react 调用setState之后发生了什么

  • nodejs事件循环机制

  • pm2的原理,有哪些模式(cluster fork)

  • docker和k8s有了解多少(k8s听过没用过)

  • 移动端端一个元素拖动,如何实现和优化(节流、改变位置)

-for in/for of 看代码输出

  • 几道看代码说输出(忘了具体题目了)

  • 描述链表的反转怎样实现,复杂度多少

编程

  • 实现instanceOf
  • 实现一个对象被for of遍历
  • 实现链表的添加、删除。复杂度多少

一面考的都是一些基础知识,需要一定牢固的基础知识准备才行

二面 时间 一面之后的下午

  • 给了两段效果上都可以实现child 继承 parent,细节上的差别

    function child(){}
    function parent(){}
    child.prototype.__proto__ = parent.prototype
    child.prototype = new parent()
    
  • 一些代码看输出的题目。考点有函数this指向的问题

  • 如何监听html外链资源加载失败(面试官又追问了onerroraddEventListener的error都能吗。面试官说onerror不行,具体我没试过...)

  • Mutation ObserverIntersection Observer使用场景(Intersection听过没用过)

  • 127.0.0.10.0.0.0差别(一个只能通过localhost ,一个可以通过本机ip或者localhost都行)

  • 利用promise js sleep函数实现

  • jsx转换后是怎样的

  • redux compose函数做什么的,中间件呢

  • redux-saga是什么,和redux-thunk有什么区别

  • dva有了解吗

  • umi.js有用过吗

  • req.pipe(res)

  • stream 如何处理数据消费和数据生产的速率不一致问题

  • writeable stream drain事件是做什么的(这是和一个控制读写速率有关的事件)

二面考得比较细,问了很多看代码问输出的问题,也问了一些比较细节的问题,有些细节的地方确实实际也没接触过。

字节

字节是通过一个同学内推的。字节也是自己比较中意的公司之一吧。为了准备字节面试,刷了不少leetcode,虽然好像面试也没怎么考,但是通过这段时间刷leetcode,不得不承认感觉自己的代码能力也有一定提升

某个周日晚上20点

一面

  • 常用的http状态码(101 200 204 301 302 304 307 400 404 500...)

  • 301和302的区别(永久/临时)

  • 前端路由怎样实现(hashchange事件 hack history.pushState)

  • 前端路由直接刷新404怎样处理(404时重定向到index.html 如nginx)

  • 从前端到后端全链路如何设计实现一个登陆的流程(session方案、jwt)

  • 什么是跨域,怎样处理

  • 简单请求和复杂请求的区别

  • 浏览器的缓存策略说下

  • domain属性解决跨域。几种domain设置对跨域是否生效

  • ts 泛型做什么的,infer关键字的作用

题目

  • 实现typescript的ParamtersReturnType (考察infer关键字使用)

  • 实现Promise.all (每个promise resolve结果存数组,最后一个promise返回时,把数组返回)

  • 实现一个并发请求控制函数,限制并发数

二面 一面之后马上进行了二面

  • jwt的原理(以前用过,比较好说)

  • xss和csrf是怎样的,如何去解决

  • pureComponentComponent的区别(前者shouldComponentUpdate默认比较props)

  • react hoc hook解决了什么问题

  • 有哪些常用的react hook,它们做了什么(useState useReducer`` useContext等等...)

  • 项目实现一个中间层的意义(前端全链路日志打通)

  • setState同步还是异步

  • setState传递对象和函数有什么区别?如何选择

  • 合成事件怎样的,有什么好处

  • 事件冒泡和事件捕获的区别、react中的冒泡和捕获呢(react中都是合成事件,无论冒泡和捕获,对应于原生事件都是冒泡)

  • 怎样看待加班(hhh 加班很正常啦,在腾讯的时候也是每天加班)

  • 为啥选择跳槽

题目

  • 实现css垂直、水平居中

  • 实现bind函数

  • 实现快速排序

三面 三面是leader面,某个周二下午进行

  • 为什么之前拿了实习offer没来/下一份工作有怎样的预期

  • graphql相比restful的区别、优点缺点()

  • 为啥选择了redux-saga作为解决方案(解决异步优雅/提供很多工具函数)。redux的异步中间件方案有哪些,对比。saga对比dva

  • graphql的鉴权在哪里做

  • 协程是什么(语言层面实现的并发),Go/nodeJs怎样去实现协程(Go使用go关键字、node可以使用Generator实现、我理解react16的异步渲染也是协程的实现)

  • react fiber的机制是怎样的

  • 锁机制的作用,node和Go如何处理死锁

  • Go/node实现并发怎么做

  • node和Go的优缺点怎样理解

编程

  • 实现一个useState

三面可能因为简历写了自己写过一些Go(其实我只是个人项目的一些玩具),面试官问了不少node和Go的问题,然后我就先表明Go自己只是简单学过,然后就按照我的理解回答node和Go的问题..幸好感觉回答得也7788吧

四面 因为某些原因,前3面发了offer后我选择换了部门,于是就有了4面

  • 介绍项目 项目难点

  • 项目做了哪些优化

  • 一个广告页面,如何统计在不同平台上的停留时间

  • 为何选择换工作

四面基本上都是聊项目,难得没有做题。我们准备面试的时候一定也要先整理下自己的项目的一些难点之类的,所以四面过程还是比较轻松的

字节感觉总体难度是这4个公司面试难度最大的,写代码也是最多的,而且感觉面试的时候写代码真的比平时加了不少debuff,这个还是非常考验心理素质和代码能力的。最后还是有惊无险拿了字节跳动的offer啦~

写在最后

这就是本次跳槽面试经历小总结。忠告各位:目前大环境也确实不好,各位跳槽要慎重,千万别裸辞~

码字不易,据说点赞的人都能收割offer~

更多好文,欢迎关注公众号Geek技术前线