首先呢我的面试经历和一些面霸和收割机的大神相比绝不算丰富,但我这三个月应该能代表很大一部分人的心路历程: 从无忧无虑也无知的状态,然后遭遇挫败,跌入低谷,连续数天的黑暗,慢慢调整,逼着自己不能松懈,看到改变,收获肯定,分享经历。
先大概说下自己的面试经历吧( 详细的面试过程和面试题解析在最后 ):
相关的公司有四类:
网易是第一家参加笔试的,面试会报销费用去总部,所以还是有难度,这个公司呢,内推不内推都要参加笔试。所以笔试要好好准备(当然笔试也不好准备)
头条只有四道编程题,一个人做确实难度挺大的,尤其是工程为主,不太专搞算法的同学。
这几个公司面试一定要现场,很多都要求去总部,还不报销路费。所以在遇到这种情况时,大家要有选择的安排,毕竟时间和精力都是有限的。
文章最后的面经当然只包括第三种因为笔试这东西真的不好讲,杂七杂八什么题都有,编程题大多人也要看发挥。
然后这是我最直观的感受( 我就从左到右说起吧。):
其实每个阶段的改变,也都是心态转变的过程,所以首先要说的一点,就是心态。在上面这种公式里,心态作为一个因子存在。没错,心态可以影响你面试的准备,笔试的状态,实力的发挥,可以影响一个面试过程的方方面面。心态崩了,就只剩运气了,offer估计也就走远了。
那怎么调整自己的心态呢?
不轻视指的是我们都要对自己有信心,毕竟选了这个行业和方向,说句不好听的话,机会那么多,就算你不怎么努力也会有个差不多的offer不是么?千千万万的初中创公司,各种拥有垂直领域稳定份额的二三线公司甚至有些已经上市,除此之外还有银行,投资,金融的IT岗,还有各行各业为了互联网+的策略而扩展的互联网分支(当然像链家这种已经算互联网+传统行业的典范了,我前些天还瞅到了像万达德勤一类的各行业巨头也在招程序开发…)所以啊,要对自己有信心,在这个行业十分缺人的年代里(当然各个层次的公司缺人的标准是不一样的),总不至于会失业吧。
不高估就是要清楚自己的能力范围,不是说期望过高不好,但过高的期望会让你的心理变得脆弱,稍有不顺心态就有崩掉的趋势。因为面试毕竟有太大的偶然性,就算你达到了一定的水平,相应水平的岗位也不是百发百中的,更不要说身边有那么多大神和收割机,天天拿offer拒offer,对心理都是不小的冲击。
大多数的人,总暗示自己说什么时间不多了,怎么每天过这么快效率怎么这么低。到笔试了,跟自己说这个算法太难了,肯定做不出来;临到面试了,跟自己说千万别问我linux内核,别问我分布式,问我肯定完;面试过之后,没有结果,就天天想肯定又挂了,唉我怎么这么菜。
如果这一系列的表现形成习惯,那心态这个系数最多0.5,能发挥出来的东西也都打了一半的折扣。凡事都不要太悲观,一个offer没拿到,正常情况是这个失败的经历产生的经验和总结是会让下一次的成功率提高的,千万别因为这些消极的暗示,反而让该有的提高都没有了。
心态差的时候反而要停下你重复而没有效率的工作,去调整一下,可以出去玩一玩,吃吃喝喝,不要把这几个月看得有多么不一样,好像耽搁两小时就要来生再见一样。
对自己的水平有个很清楚的认识,并选择自己合适的公司,好好准备自己的笔试、面试,不怕失败,但保证每次面试都有收获和提高,那满意的offer早晚会来。
这里说的实力指的是硬实力,也就是技术上的真实积累(当然产品岗的就是对于产品相关知识的积累),而其实呢软实力在面试过程中也尤为重要(有时候真的要更重要),主要是指和面试官的沟通,对一个问题的阐述方式和表达方式,逻辑思维能力以及的价值观和为人等。
如果你平时有些项目积累,不擅长也从来没有怎么系统地总结过;如果你学习呢不算那么认真刻苦,研究搞得也不算出众,但是你该努力的时候也会努力,可以为了一个好的工作逼自己一把。
那也许下面说的实力和技巧都可以在一定程度上帮到你。(因为我就是这样的情况)
这么说是因为很多人其实在这些年的项目或是学习中有一些积累,但是在刚开始面试的时候完全感觉使不出力,就是有种你问的我都能讲上一点,但根本说不清楚的感觉。(往深了问自然是完蛋)
知识面或者或者说技术栈都是有宽度和深度的,我们要做的就是在短时间内提升宽度,抓住以往本身就熟悉或是感兴趣的几个点去深入。
我是认为知识的 宽度可以很大程度上决定你能不能通过面试 (这里说的宽度并不是简历上了解、知道或者你都没往简历上写,仅仅是听说过的层面修饰的方面,而是写熟悉的那种,通俗地说是可以讲清原理,不涉及横向对比和优化的方面)
一两个点的 深度呢在保证你能通过面试的同时(尤其是你的点正好cover了对方部门的技术栈),并且还是影响offer等级的关键因素 。(达到足够的深度,不只能说出原理,还能进行横向技术对比,纵向的延伸技术,优劣点及优化,或者在这个点写了几篇很透彻的博文,更厉害的同学甚至有相关的开源项目的参与与贡献)
关于怎么提升宽度和深度可以看下面的积累(其实说真的短期内宽度是好补的,深度确实要看个人,是代价较高,性价比不一定高的一方面,看自己的决定吧)
所以我的建议是, 先把宽度提上来,把你能cover的知识点及原理搞懂是第一步。建议对自己之前的项目和技术积累做一个总结和分类(可以参考下面的技术路线),然后对已经了解的方面尽可能延伸,对盲区或是薄弱的地方进行针对性的学习和练习。
当你的知识面覆盖到一定程度的时候,你自然会把他们的联系搞明白,慢慢理解这整个技术体系,在面试的过程中结合表达技巧可以关联起来说各个方面,也就可以很大程度上展现自己的真实实力(更厉害的同学甚至可以有超出自己真实实力的表现。。)
2.2 实力包含哪些方面
(我也只是脑子里过了一遍,肯定有遗漏的,大家自己补全就行了,毕竟每个人的知识覆盖范围也不同)
积累实力最好的方式就是平时在项目中或是学习中,多学多问,多思考多钻研。这里就说说短期内学习的一些方法和路径:
总结下来,一方面是通过看书、看视频、看面经来不断扩展自己的知识面,一方面是通过不断的面试积累经验和知识盲区,在每次总结的过程中积累实力。
先说说看书学习这一点
这里应该是有个推荐书籍的环节,这几个月确实看了不少书,但是并不是所有都有很高的性价比,在这边大概列一下, 前后顺序也一定程度上代表了我认为的重要度先后,'/'做分割的是一类的书籍,一般来说看一个就够了 :
书单:
除了上面说的书和视频,最有用的还是大家分享的各种面经。
我当时是每天晚上在床上看几篇面经,然后把存疑的问题copy到记事本中,第二天找个固定的时间短查询解决和总结。长期下来会养成一个很好的习惯,你的知识点会不断地扩充。
这一点其实跟刚刚看面经的那个很类似(那个我不是叫做模拟面试了吗),每次面试完,一定要把自己不会的东西尽快记下来(当然你如果有记面经的习惯就更好了,还能再分享出去),然后找时间弄懂和总结。
除了知识点,每次面试(跟模拟面试不同的地方)还要总结的是哪里发挥得不好,哪里有可以提升的地方,下次一定要注意之类的。(就是有关面试技巧的东西,比如这次语速太快,导致面试官反馈了,又比如这次发现对方让你在纸上画个项目逻辑图突然一时脑梗,那回去就好好在本上画一遍)
软实力这个东西与面试的准备关系不大,基本上是长期形成的。
包括和面试官的沟通(有的时候也会成为聊天瞎扯的能力);对一个问题的表达方式,逻辑思维(像有些人的发言就让人听上去很有层次感,很舒服,这方面欠缺的可以推荐玩玩狼人杀);除此之外对方也会很在意你的价值观和为人(这个是我进了公司发现的,很多公司在内部的面试细则上面都会注明这一点,如果价值观或是人品问题会直接否决。)想想也是有道理的,因为这个是入职之后能不能好好相处的关键,设想如果你是一个面试官,面对一个有实力但是说话太有棱角聊不太来的和一个不算出众但基础不错很听话可以培养的,你会选哪一个?(如果你因为生活太平淡了想选第一个,那这一条当我没说。。)
这些软实力其实要在生活中慢慢锻炼,比如多参加些活动,多和别人沟通,发表意见前好好组织自己的语言等等。(每个人都有每个人的性格,这些都因人而异,但有一点我们要记住的是在面试中, 不论什么情况,都要保持冷静和清晰的头脑,和一个谦卑的态度,交流要坦诚 <尤其作为应届生>,这样起码印象会好很多,要知道虽然面试有各种各样花式的打分项,但是印象好往往是隐藏的决定性因素)
面试的技巧首先就是刚刚说到的态度。 一个谦卑(注意不是自卑,也不是把自己放的很低的样子)和礼貌的态度和表达方式往往可以让面试官的印象分提高很多,印象分很像之后要考察的实力分的系数。留个好印象,面试就成功了一半。(当然你一定也听过那种聊得很嗨,或者偶遇校友之类的,毛都没问就聊通过了的场景。这种情况还是不算在技巧中了吧,应该属于运气和缘分的范畴。而大多时候聊得开心和舒服会让你感觉到通过率会比较高,这一点很多人还是深有体会的)
首先从简历开始说,简历怎么调格式,做几页,排版啥的就不想多说了,感觉很多文章都分享过。我只说说技术方面的内容怎么写。
专业技能的描述谓词无非就那么几种: 精通、熟练、熟悉、了解 。(还有一级叫听说过,这个级别的可千万别往上写啊兄弟)
精通感觉一般还是不要写,除非你在某个技术点上真的有足够的把握,比如源码看的很透彻的同时还能深刻理解原理并能灵活处理各种case场景,如果还有相关的开源贡献,那就自信地写精通吧。
我们把自己掌握的大多数技术点叫做熟练掌握,这个需要我们 在之前对各个技术点进行横向纵向的复习和总结 ,并不只是用的多有经验就行,有的时候我们觉得熟,但真让你说的时候却不知道从何说起。
至于熟悉和了解,可以写一些自己理解原理但是不常用的技术点,尤其是比较流行的,各大公司都在用的技术(比如MQ,分布式缓存等等),这些你在学校不一定用过,但是你可以通过看博客,写demo去理解他的设计和原理,面试的时候可以讲得清楚。
这里还有个技巧,更细心的同学可以针对每个公司岗位的job detail不同,熟悉和了解这块就针对jd中cover的技术点去写。这个做法是很聪明的,毕竟熟悉和了解这个层面是可以提前学习和准备的,有针对性的去写对方需要的,是提升通过率很好的一种方式。(如果嫌麻烦就算了,比如我就是)
下面再说说项目经历这块:叙述一定要精炼到位,细化到每一个亮点上。我现在再看我二三月份的简历简直是有种想撕了的冲动,当时就是项目描述两三行,然后概括下我大概做了哪几个模块。完了。
事实上,不能讲得这么泛泛,就从中找2-3个亮点,一句话高度概括,突出亮点。
比如后来我就把我一个普通的web项目挖出来三个点(爬虫,通信控制方面,安全加密方面),分别用一句话叙述,这一句话最好包括这个技术点的思路,解决了什么,有没有做什么优化。比如一个爬虫工具可以写成这样:
我负责这个系统中爬虫的开发,终端控制管理,店铺管理。。。。
是的,上面这个爬虫就占用了五个字,等于没说,面试官看到压根不知道怎么去问。这里还可以这样写:
负责系统中爬虫模块的开发,用于爬取影片的各种信息,包括年份,介绍,主演信息等。
这个起码告诉面试官爬虫做了什么,但是你并不能保证他会问,因为你的叙述不一定能引起他的兴趣。那还可以这么写:
独立开发多线程影片信息爬虫工具, 并针对线程池性能、网络异常以及反爬虫措施进行多次优化,容错性良好并达到并发请求30+的QPS。
你觉得面试官看到这句话,他不想问点什么吗(除非他真的就不想要你)。
所以说,其实面试官呢都是希望在面试的过程中发现我们的亮点和优势,从而展开更深层次的交流,但是往往在简历中没有一个让他询问的入口,这样就可能导致他会随意问(比如你了解什么什么吗?一般情况下都不太乐观),或者就说那你来讲讲吧(这种问法其实已经表达出他不知道怎么问的情况了,你在讲的时候一定要突出重点,否则会让人感觉没什么亮点,普普通通的项目而已(当然就算是普通的项目,我们也要挖掘它的价值和自己的价值不是))
我们在面试的过程中最重要的是自己掌握主动权,如果面试官问的都是我们熟悉的范围和准备过的领域那我们答起来也会更加得心应手。而让面试官随着我们简历中埋下的这些亮点(他就算知道你有意想说这一点,往往也会去问,因为他就是想在短时间的面试中了解你处理问题的能力),去进行更深层次的交流,而这个更深层次的交流,还需要我们针对简历上的每一句话,都准备多个层次和维度的扩展。
比如还是这个爬虫,你可以充分扩展线程池的相关优化(有可能项目中没有怎么优化甚至就是个单线程,但是在准备面试的过程中还是可以专门去做一些code重构的),优化网络的NIO相关扩展,以及反爬虫的各种各样的措施,以及爬虫方分别如何应对。这里只要你去想,能准备的东西太多了,面试多了自然也就越来越熟,好像项目就是做得这么完美一样。
这里我就不怎么扩展去说了,再讲下去这篇文章就写不完了。。。
好好对着自己写的简历一行一行看一遍,这都是你挖的坑,是准备给面试官作为切入点交流的,并不是自己往里跳的。(对每一行都要有足够了解和把握)
面试过程不要紧张,尤其是前几次,建议先从小公司入手锻炼下面试经验(参考我之后自身的反面教材
面试方式不同,侧重点不同(无非是电话、视频、现场三种)。
学会平等交流,别把自己身段放的太低。其实有一点你要清楚,面试是个双选的过程,他可以拒绝你,你也可以拒绝他。千万不要太上赶着,反而会影响自己正常的表达和逻辑。(就跟你见了喜欢的姑娘就不会说话了一个道理)
回答问题的时候不要一口气把知道的全部说完,然后还毫无条理。学会一个知识点由浅入深讲解给面试官,并且留有余地给他进一步去问。
举个例子:
如果真的不巧聊到不擅长的地方,学会转移话题,从一个点中聊自己感兴趣或是有把握的方面(比如你对消息队列不太熟但是redis用的熟,你就可以在问到消息队列的时候说,因为之前都是自己做的项目嘛,性能方面没有考虑到最优,一些异步的方式还是靠redis list去实现的,虽然redis的消息机制并不常见,但当时还是满足了需求,之后可以考虑性能方面的提升和技术评估;又比如问你http请求细节,rest的设计实现细节,你可以说http restapi服务接口性能的一些不足,后来使用了rpc的方式,当然你这么说一定是要对rpc很了解)其实有的时候面试官是知道你是有意转移的,但是往往他们也不会抓着你不会的去问,非让你自己承认自己的盲区,他们也许根本不在意这些。
如果真的被问到不会的,就直接说你不会(说你不会、说你不会,我再补充两遍),或者礼貌地说这方面可能我还要多学习。(对一个拿不准的问题千万不要猜,即使是二选一的那种问题,猜错了直接完蛋,猜对了被人看出来,再往深问还是完蛋)另外,像可能,大概是,我觉得这种表达最好不要,一听就是对一个点没把握,有可能会让面试官觉得学习太浮躁不喜欢寻求原理。
那对于自己知道原理(确实是理解了的)但是没用过的东西,就讲讲原理,并承认自己实践不足,表现出好学的态度。面试一定要真诚。
问到有什么offer就直接说,不要藏着掖着,也不要把更好的offer(比如bat的)讲的非常诱人,一副bat我都拿到了的样子(面试官会心想,那你还来面试我们干什么)。再强调面试过程一定要真诚。除了直接说,诚实点之外,也要真的做些思考:对方公司跟之前的offer比优势在哪,比如平台更大?专业技能栈更match?工作更有挑战力?地点更合适?有机会留用?随便一条符合的都可以讲出来,起码让对方觉得你想来面是有原因的并且真的有可能加入。(如果你还提前了解对方公司的文化,可以讲出这个文化自己很认同那就更可以了)
关于这一点只有一句:平时多做好事,热爱生活。
其实都知道面试要讲缘分,讲运气,但人往往可以在很顺利地通过面试之后说句运气好运气好,却很难在努力准备却失败的经历之后保持平静。
但不管能不能转运是不是本命年有没有缘分,努力和收获的关系总是多年不变的真理。
所以,讲心态,讲实力,讲方法。足矣。
按时间顺序,详细叙述一下我面试的过程,包括面经和心态的转变:
( 括号里是对问题的补充,如果感觉有知识点的盲区,大家正好可以去深入学习一下。这里说一下我投的大多是Java研发岗,所以其他语言的可以忽略java问题 )
首先说一点, 复习准备一定要早 (当然这是说给19届师弟师妹们听的,嗯你们看到这里已经可以开始复习了),有同学去年暑假剑指offer都刷了一遍,然后我竟然今年3月才买这本书。。还有同学前一年冬天就已经去实习了,这种机会也不错。但寒假如果不实习的,一定要进入到学习状态。我准备的就有点晚,寒假完全没看书,真正开始准备,大概是2月中旬号玩了一晚上狼人杀之后。
就是那个时候发现校招就要开始了,然后开始慌了。大概看了一周的书(基本上都是java基础),然后师兄说阿里内推了,心想赶紧投吧要不人家招够了就不招了(后来发现都5月6月了还在招。。),然后就慌慌忙忙投了简历。
这里我要说一点最重要的事情: 一定不要在没有面试经验的情况下先面大厂,或者是你想去的公司。
我是3月1日下午三点半在阿里的官网完善的简历,5点电话就过来了。作为一个java coder,阿里是个很好的平台,(当然C++的岗可以好好准备腾讯),一定还是准备充分了再投, 你先面的结果很可能是焦急地等一两个月然后被后来准备充分再来面试的人取代。
两天各面了一面(投的蚂蚁金服,第一天面的就不太好,第二天又把我捞起来面,并且面完感觉就走远了,但当时却没有reject,这就导致之后一个月一直在流程中,阿里其他事业部的师兄师姐没办法把我的简历提走,最终到要笔试了然后变成了rejected)
那个时候就是处于我所说的无知状态,知识点掌握的不够牢,简历写的乱七八糟,面试经验为零(这应该是我上学以来的第一次面试),面试技巧就更不懂了。
然后当时两次都感觉聊得很差(尤其是聊算法模型的时候都想自爆了),也根本没有记录面经的想法。所以有些问题我都记不起来了,大概说一下吧。
其他问题真的太久远了,我当时也没有记面经的习惯,所以就没有了。但是最大的感受是面阿里的时候整个人都是紧张的状态,语速特别快,恨不得把知道的都说出来,没有条理,并且把自己姿态放得特别低,还在楼道不停走来走去。(对,以上说的这几点全都是不应该的,但主要原因还是当时准备太不充分,简历方面的准备以及知识点的积累都不够;另外一点,还是要强调不会的就是不会,千万别说大概是,我觉得吧这种东西,说的不好很容易让面试官认作不懂装懂,虽然你只是很想向面试官表达点什么,哪怕只是积极的态度)
从阿里面完试开始我的心态基本上就崩掉了,对自己极度怀疑,加上今年诸事不顺,心情直接跌到了低谷。然后整个三月基本上都是黑暗的,整个一个月都没再投内推,每天从早晨起来,大多时间就在看书刷题,晚上十点回宿舍躺在床上,还要刷两个小时牛客的面经。一个月下来很少说话,提升肯定是有,但是这个过程,其实完全可以用更好的心态去经历。
然后这段极其黑暗痛苦的日子持续到三月底,一个师兄想帮我内推百度,因为之前因为没信心也错过了腾讯的内推,就心想要不试一下吧。
这里可以提前和学习,即使你真正使用的只是一点,也可以在相关问题上做更深的了解。
最简单只分析请求,拦截所有非浏览器的直接请求(可以通过添加伪报头解决);查看refer页做防盗链接(可以改refer项);基于用户行为的策略,同一ip相似请求判定(代理或ip池,或间隔请求解决);基于用户session的策略(模拟多用户登录解决);封装前端数据,用js渲染生成(通过探取和模拟异步ajax请求解决);对ajax请求进行加密等等方法。
有了信心或者说有一个offer之后,你就会越来越顺利,从这之后的每次面试都会有不同程度的收获。360的流程是走得最顺利的,笔试+面试,三次面试一天完成,但是360的面经可能写得稍微简单一点,因为很多知识点在后面的面试中也出现了,就没有做过多解释,腾讯滴滴美团的面经要详细一些。
这是唯一一篇hr面经,因为我只面过这一次hr,其他的三面要么是技术,要么只是打个电话说说情况,还没问问题就挂了电话(比如腾讯的)。
hr面没有太多经验,个人生活爱好这类我感觉就是放轻松聊,规划方向这些可以自己提前准备准备,但是比如创业,offer(之前说过了),价值观一类的问题,其实你也不知道对方想要什么样的回答,干脆随缘吧。
腾讯的面试有一点印象很深,很考察思维能力,经常会有一些意想不到的问题,或者智力题。挺有意思。
二面其实就两个大问题,但一直往很深的地方问。
两面完了电话让去参加新锐的现场终面,很有诚意地报销了所有的花销。新锐的三面还是有难度,基本上围着算法在问。
算法:int范围的随机数的阶乘编码实现。
(这个题如果直接按最简单的算法题肯定是不行的)
1.首先考虑要用字符串做运算(因为中间数太大了,只有String能保存,当然你可以借助BigInteger或BigDecimal类去辅助实现)。
2.阶乘直接计算代价太大,循环太多,考虑设计中间缓存。(正常算复杂度太高,本身就是阶乘级的,所以正常想到用时间换空间)
3.只用空间换时间的话缓存也不能覆盖全部,如果把所有的中间值保存,空间是eb级别,不现实。(这里就要达到一个空间和时间复杂度的平衡点)
4.存部分中间值用部分空间换取时间,达到空间复杂度和时间复杂度的最优平衡。(开始说的二分做分割存储之后改为等间隔做分隔存储,间隔选取多长为好?我觉得要首先确定空间复杂度的接受极限,然后尽可能减小时间复杂度,因为空间复杂度是可以有预估值的,而时间复杂度当然我们是希望约小越好的)
(这里说一下,我并不是一开始都想到了,只是面试官一直在提示我思路,给我时间思考,没有否定过我)
其实大家可以从这个过程中看出来,随着时间的推进,自己的知识储备和各方面的经验和能力都是上升的。
总结几句:
一两次甚至一系列的失败并不可拍,成功之后反而没有失败总结得透彻,收获的多。 失败的经历会让你不断提升能力,成功的经历会让你不断提升信心。而不管成功失败都会提升你的经验,都会有收获。
作者: XiaoTeng
链接:
https://www.nowcoder.com/discuss/29890
已与作者进行私信联系, 任何人转载此篇文章,文章出处这一栏都不可以删除。
公众号作者乔戈里亲历2019秋招,哈工大计算机本硕,百度准入职java工程师,欢迎大家关注我的 微信公众号:程序员乔戈里 ,公众号有 3T编程资源 ,以及我和我朋友(准入职百度C++工程师)在秋招期间整理的近200M的面试必考的java与C++ 面经 ,并有 每天一道leetcode打卡群 与技术交流群,欢迎关注。