程序员简历优化之道

为什么你投十份简历,只有一两家公司约你?又或者为什么你每投一份简历都能获得面试机会?

最根本的原因,就是一方在汲汲渴求,而恰恰另一方呈现出的关键点让其怦然心动。求者心中有所想,而应者恰恰展现了求者所想的那一面。这就是个中奥妙。

程序员在找工作时,在一开始有三件事情会对能否获得面试机会至关重要:

  1. 知识、技能、经历梳理

  2. 确立求职目标

  3. 简历优化

知识、技能、经历梳理

知识、技能、经历,这都是一个人能体现出来的商业价值。一家企业招募某个人,一定是因为这个人可以帮助企业在某方面实现价值。而且,正常情况下,个人的贡献一定要大于企业为这个人负担的各种成本(薪水、社保、公积金、个税等)。

所以,作为程序员,我们一定要清楚自己的价值在哪里。个人的商业价值,可以通过下面五大要素分析出来:

  • 知识

  • 技能

  • 经历

  • 天赋

  • 人脉

我们在招聘网站上填写简历时,内容最多的就是前三个要素,都是差不多的模板,填下来千人一面。

在最开始的时候,不建议直接到招聘网站上填写简历。强烈建议先用 word 或 MarkdownPad 来整理记录你认为你具备的所有有价值的知识、技能、经历,不论大小,统统记录下来。这是我们后续优化简历的基础,也是确立求职目标的基础。

知识与技能

有必要说一下知识和技能的区别,这是很多人常常混淆的。

知识可以通过语言文字、语音、视频等进行传授,比如像 C++、Java、数学、物理、Qt、Android、设计模式、网络协议等都是知识。

技能是指按照某种规则应用知识和经验完成某种任务的能力。比如使用 Qt 开发桌面客户端软件就是一种技能,使用 Java 和 Android 界面类库开发 App 也是一种技能。

我的知识大概有这些:

C、C++、Java、Scala、Python、Qt、MFC、WTL、QML、Qt Quick、JavaScript、HTML、CSS、Lua、MySQL、MongoDB、XML、Json、Win32 SDK、Node.js、AngularJS、ffmpeg、VLC、DirectShow、Android、Objective-C、HTTP、 P2P、RTMP、RTSP、HLS、P2P、socket、UML、软件开发模型(瀑布、迭代、Scrum 等)、项目管理知识、团队管理知识、微信订阅 号管理。

知识会淡忘,一段时间不用就扔掉了,所以在你的知识图谱里,一定有一些是你经常使用的,比如我最熟悉的就是 C、C++ 和 Qt。

我们需要把自己最熟悉的三种知识标注出来,后面会派上用场。

技能就是对知识的运用,所以一般来讲你有什么知识,就能找到一组技能。比如我可能有下列技能:

  • 使用 Qt 开发客户端软件

  • 使用 Qt 开发服务器软件

  • 使用 Java 开发 Android App

  • 管理项目,制定项目计划,跟踪计划,控制项目进度

  • 团队管理与激励

  • 博客、微信订阅号等自媒体运营

  • ……

好啦,现在我们应该可以进行知识和技能的梳理工作了。

需要特别注意的是,每个人都有很多知识和技能,一定要找出你擅长的 2~3 种知识,2~3 种技能,这将是你求职时的重要参考。人只有使用最擅长的技能去做事情,才能达到最好的效果。

经历

知识和技能可以帮助我们创造商业价值,而知识和技能的积累过程本身也是有价值的。积累知识和技能的过程,就是经历。

程序员的(学习、工作、项目)经历具有非常独特的价值,在求职过程中往往会发挥非常重要的作用。比如你做过视频项目,那再找类似做视频的公司就很容易脱颖而出;比如你做过图像处理相关的项目,进入美图秀秀之类的公司就相对容易……

在回顾项目经历时,关于你自己的那部分,一定要想明白并记录下来,从下面三点来挖掘你的亮点:

  • 你负责的工作内容

  • 用到的知识、技能

  • 你对整个项目的贡献(最好可以量化)

我的一个项目经历:

【互联网视频卡顿优化】 
 项目描述: 
   智能机顶盒上的视频聚合客户端,在播放视频时,高峰时段或热点视频,经常卡顿。针对此问题,进行优化,以使能够对用户提供流畅的观看体验 
 业绩: 
   播放效果大幅度提升,卡顿投诉下降 80%。 
 职责: 
   作为项目经理,负责项目范围界定、进度跟踪与控制 
   作为系统设计,选择技术方案,设计加速与优化算法,设计系统结构。 
   作为核心开发人员,负责客户端 http 基础类库的开发和服务端 http server(基于 Qt) 的开发。

我没有列出前面所说三点对应的所有内容,个人亮点也没完全写出来,但你的心里一定要清楚,你发挥了什么关键作用,如果有攻克技术难点的经历和明显可以量化的业绩,一定要总结出来,面试时经常会被问到哦。

天赋和人脉其实也是个人非常重要的商业价值。但在程序员的简历中较难体现出来,在面谈中倒是有较多机会展现。

确立求职目标

不管是从大学走向社会的初次求职,还是在职场摸爬滚打了 N 年的老鸟,找工作时都要忌讳一点:茫无目的,漫天撒网。

求职时,明确目标行业、企业、职位,有针对性的做准备,事半功倍。

职业延续性

跳一次槽换一个行业,跳一次槽换一条技术栈,这样极其不利于程序员的商业价值积累(知识、技能、业务等)。假如你不是第一次求职,就有必要考虑职业延续性。

假如你现在在金融行业,那换工作时,最好还在里面。这样你的行业相关的经验就可以积累下来,慢慢形成优势。假如你现在做 iOS 开发,最好换工作时还找 iOS 相关的,这样你的 Objective-C 啊,Swift 啊、Cocoa 啊才能持续精进……

有 一种情况另当别论:你发现你不喜欢现在的行业和所用的技术。此时跳槽,就要找到新的方向(后面方法可以帮到你)。一旦你找到新的方向,转换过去之后,同样 要考虑以后的延续性。每次都说自己不喜欢现在的,更喜欢另一个,这样捣腾几年之后,你很可能会发现,那些闷生不响持续深耕的小伙伴们居然一夜之间都牛逼闪 闪起来了……

成就事件挖掘职业兴趣

在我们总结整理自己的工作、项目经历时,要特别留意那些让你特别有成就感的事件,它里面隐藏你的职业兴趣,可以挖掘出你今后乐意从事的职业方向。

我们可以遵循 STAR 原则来回顾成就事件:

  • S(Situation),背景情况,包括面临的障碍、限制或困难

  • T(Task),任务,目标,想完成的事情

  • A(Action),行动计划与步骤,如何克服障碍、达成目标

  • R(Result),对结果的描述,重点关注你取得了什么成就

成就事件列出来后,可以按照下面两点来深入挖掘:

  • 哪一个具体的点让你特别有成就感,比如“达成结果受到领导表彰”、“独立克服某个技术难题”、“用自己的 XXX 帮到了某某某”、“成功组织大家齐心协力达到目标”……

  • 用到了什么知识、技能

通过这样的分析,你就可能找到自己的最佳技能和工作中最在意的点在哪里,就可以根据他们来确立新的职业目标。

聚焦行业、企业、职业

聚焦的目的是缩小目标范围,节省时间和精力,深入研究分析,有针对性的对自己的商业价值进行优化组合,提高简历的吸引力,最后提升获取面试机会的概率。

程 序员运用编程语言、技术框架、设计模式、算法等开发针对某个领域问题的软件,软件必然和目标需求和业务密不可分,所以,程序员左手技术,右手业务,假如你 对业务内容完全不感兴趣,很难想象你可以把软件做好。因此,当你有了目标产业,目标公司,还要去了解这家公司做什么产品,是产品导向的公司,还是项目导 向,还是外包为主,选择那家你对它的业务范围感兴趣的公司,不感兴趣的就果断筛掉。

基于延续性的考量,以往工作过的行业领域都需要认真对待,但不一定非要继续在之前的方向上做,换一换也可以。但有一个基本的原则,离夕阳产业和走下坡路的企业远点儿。

以我为例来分析一下。

技术方面最擅长的语言是 C++,最擅长的框架是 Qt(出过《Qt on Android 核心编程》和《Qt Quick 核心编程》两本书),最擅长的是客户端软件开发。然后对 Android 开发有了解也有兴趣。新的职位最好和这两方面相关。

我锁定的第一个目标是高级软件开发工程师,语言是 C++。行业领域的话,互联网、智慧城市、企业服务等都可以。

还有,我之前都在小公司摸爬滚打,现在希望到比较大一点的公司里体验一下不同的工作氛围。

在锁定职位的过程中,还要考虑自己当前的劣势,以便在简历和面试过程中妥善应对。以我为例,如果找软件开发工作,就有两个不好的点:

  • 最近一年没做什么开发工作,会被人质疑廉颇老矣尚能饭否

  • 最近几年都在做技术管理工作,别人可能会奇怪你为什么倒回去做开发

这两点也会影响到目标职位的选择和匹配度,比如有的高级开发工程师职位要求有一定团队管理经验,那和我的匹配度就高一些。

好啦,我的聚焦过程已经完成了,接下来咱们进入简历优化的实操过程。

简历优化实操

知道了自己有什么商业价值、弄清了想到什么样的行业什么样的企业里什么样的岗位上工作,接下来就该优化简历了。

简历优化有这么几个要点:

  • 分析招聘信息,提取知识、技能、职责当中的关键词

  • 根据招聘信息里的关键词,筛选个人知识、技能、经历

  • 将匹配到的知识、技能、经历重新组织、呈现

程序员的简历,一般包含下列内容:

  • 基本资料(姓名、性别、年龄、婚否、电话、当前在职状态)

  • 求职意向(职位、工作地点)

  • 知识、技能

  • 自我评价

  • 教育经历

  • 工作经历

  • 项目经验

  • 附加信息(比如兴趣爱好、荣誉、博客、开源项目等)

根据实际情况,有的简历可能没有自我评价、附加信息,有的可能没有可写的教育经历(比如高中生),有的可能没有工作经历和项目经验(如大学生等初次求职者)。

特 别提一下程序员的一些个人品牌相关的附加信息(具体参看我的微信订阅号“程序视界”里编号 10080 的文章:这 8 种武器点亮程序员的个人品牌),比如技术 博客、github 主页、参与的开源项目、自己做的 App 等,都是能非常好展现程序员知识、技能的东西,能为你的简历加分,也能弥补面试时间短信息交流补 充分的问题。要知道,决定你能否通过简历关的,通常是另外一个程序员,而对聪慧内敛的程序员致敬的最好方式,就是“Show me the code”。

简历模板

很多程序员都使用招聘网站提供的简历模板,要在不同招聘网站上发布简历的话,可能要重复填写 5、6 次简历,非常耗时。我一般会有一份基础的 word 格式的简历,根据它在不同的招聘网站创建不同的简历。

接下来介绍我的简历,非常简单,顺次包括下列五部分内容:

  1. 个人信息

  2. 求职意向

  3. 技能与评价

  4. 工作经历

  5. 项目经验

我简历的前三部分简单如下:

个人信息

  • 男,xxxx 年 xx 月 xx 日生于 xxx 地方

  • 2002 年毕业于西安交通大学,电子信息工程专业,学士学位

  • 153xxxxxxxx, [email protected]

  • 已婚

求职意向

  • 高级软件开发工程师,西安

技能与评价

  • 7 年部门管理经验,丰富的项目、团队管理经验

  • 7 年嵌入式开发经验,在互联网电视机顶盒、车载娱乐系统、手持娱乐设备(MP3/MP4)等领域有成功经验

  • 丰富的软件系统架构设计经验

  • 熟悉常见的设计模式,有丰富的面向对象设计经验

  • 精通 C/C++,熟悉 Java,Shell,了解 python,Lua,JavaScript 等

  • 可熟练在 Android、嵌入式 Linux、Windows CE、Windows、Linux 等平台 
    下进行开发

  • 熟悉 Android/Qt(E)/MFC/WTL 等 GUI 框架

  • 熟悉 DirectShow/GStreamer/MPlayer/FFMPEG/VLC/Vitamio 等多媒体框架

  • 熟悉网络编程,熟悉各种流媒体协议(http/HLS/rtmp/p2p/rtsp 等)

  • 博客:http://blog.csdn.net/foruok

  • GitHub:https://github.com/foruok

  • 著有《Qt on Android 核心编程》和《Qt Quick 核心编程》

我工作年限长,挑最近的几段看下:

工作经历

2014.12~2015.12,陕西XX网络科技有限公司

  • 职位:技术总监

  • 职责:团队组建、管理、技术方向把握、项目管理、产品管理

  • 业绩:3 个月组建 10 人团队

2014.11~2014.12,北京XX有限公司(西安)

  • 职位:平台组高级软件开发工程师

  • 职责:跨平台软件开发

  • 业绩:解决了 Qt 在 Android 和 iOS 两个平台与原生 UI 叠加的问题

2008.01~2014.09,西安XX软件科技有限公司

  • 职位:CMC 部门经理

  • 职责: 
      1). 部门员工组织、领导、管理、激励,绩效考评 
      2). 项目计划、实施、跟踪、管理 
      3). 技术路线评估与选择 
      4). 系统分析与设计 
      5). 关键模块代码实现

  • 业绩: 
      1). 2009 年至 2010 年,负责组建机顶盒开发团队与互联网视频搜索开发团队,并带领团队,完成了技术积累和产品探索,使得公司成功进入新的行业领域,完成公司的业务转型 
      2). 2012—2013 年,负责组建智能机顶盒团队,完成机顶盒产品智能化转型 
      3). 2012.07—至今,主持智能机顶盒产品研发 
      4). 2011.10—2012.06,主持第二代高清互联网机顶盒产品研发 
      5). 2009.05—2012.01,负责第一代高清互联网机顶盒产品研发与改进

好了,我简历的主体框架就是这样子了。接下来,我会根据我的目标职位——高级软件开发工程师——来找几条招聘信息,通过分析招聘信息来优化简历的技能与评价、项目经历两个部分。这两部分也是我们优化简历时的重点。

简历优化

大多数招聘需求是由我们的同行提供的,假如能从招聘信息里反推出拟定招聘需求的那个软件工程师或经理心中的关键词,那你的简历优化就有针对性了。

下图是一个招聘需求:

图片描述

红线标注出来的,是一些关键的基本要求,C++、Qt、Windows 桌面客户端,这些是硬性要求,要应聘该岗位必须要满足。

绿线标注出来的,是软性要求,不太容易直接量化和衡量,但面试官可能会在面试中通过交谈来考察。比如软件设计能力、技术传播能力、沟通能力、沟通与团队协作等,通常都是在面试中体现,而编码能力,则可能会通过笔试或者面试中不断的询问技术细节来检验。

蓝线标注出来的,是优选条件,在有多个候选人的情形下,你具备了这些要素,就会被优先考虑。

一般的企业处理软件开发工程师的简历,是 HR 先挑,然后是技术人员(程序员或经理)再次筛选,通过技术人员的筛选后,就会通知笔试或者面试。

HR 拿到招聘需求,会和技术人员沟通要关注的关键点,然后根据这些关键点挑选合适的简历。通常在 HR 眼里,关键点就是关键词,所以,** 我们修改简历时,尽可能使用招聘信息里出现的字眼,便于 HR 识别。**HR 看一份简历,多则一分钟,少则 20、30 秒。

技术人员筛选简历,通常比 HR 要细一些,大致分两步,先筛关键词,然后是看项目经验里是否体现出了他们发布的岗位需要的技能和软实力。关键词匹配不上,PASS,30 秒不到;能匹配上,继续看项目经验,整个过程可能会持续几分钟。

在看项目经验时,一方面看应聘者在项目中是否用到了将来需要的相关技能,另一方面看具体项目内容,做行业、产品、业务相关性比对,如果应聘者做的产品与招聘方要做的相关性高,就会被优先考虑。

通过对简历筛选流程的了解,可以知道关键词的重要性了。那接下来我们就要依据从招聘信息中提取的关键点来修改简历了。

在修改简历时,我的做法是尽可能多的在简历中体现企业要求的技能及软实力。一般可以在下面两处反复琢磨:

  1. 技能与评价

  2. 项目经历

结合我的简历,先看技能与评价部分怎么修改。

因为目标职位是高级软件开发工程师,招聘信息也没有特别体现对管理能力和经验的要求,所以我的管理经验可以淡化或拿掉。然后是突出 C++、Qt、软件设计、技术传播等内容。新的版本如下:

技能与评价

  • 9 年 C++ 开发经验,精通 C++,熟悉 STL

  • 5 年 Qt 开发经验,基于 Qt 开发过 8 个商业项目,代码超过 30 万行

  • 著有《Qt on Android 核心编程》和《Qt Quick 核心编程》

  • 熟悉面向对象编程

  • 熟悉 GoF 设计模式

  • 丰富的软件设计、软件架构经验

  • 熟悉 MFC,熟悉网络编程,熟悉多媒体及各种流媒体协议

  • 热衷技术传播,推动了 Qt 在团队和公司内的普及

新版本兼顾了硬性要求、软性要求和优选条件,与初始版本有明显不同。

接下来,我们就要重新组织、呈现项目经历,让它更多地体现企业 HR、面试官所关注的关键点。下面是我的一个具体的项目经验:

2009.05—2011.09,跨平台视频点播系统

项目描述:面向电信运营商和零售市场的综合性视频服务产品,具有视频导航、搜索、点播、直播、天气、资讯、股票、教育等功能。产品形态有机顶盒、Windows 客户端、Linux 客户端等。

软件环境: Embedded Linux,Qt Embedded 4.5.1,Qt 4.5.1,C/C++ 硬件环境:全志 F20 芯片方案、PC

角色:项目经理、核心程序员

职责与工作内容: 
  1). 软件系统结构设计 
  2). 基于 Qt GraphicsView 框架设计实现十字菜单、影视信息墙  
  3). 基于 Qt 的客户端业务流程代码实现 
  4). 基于 Qt 实现认证模块 
  5). 团队组建与项目管理 
业绩: 
  1). 开发了稳定、性价比高的互联网机顶盒产品,打开了电信市场,销量超过 30 万台。 
  2). 在团队里推广 Qt,形成了技术积累 
  3). 提供 Windows 及 Linux 客户端,为客服、运维、售后提供了强有力的支撑 
这个招聘需求,和我的匹配点主要在技能(C++、Qt),接下来这个,责主要匹配的是业务(行业)经验。

图片描述

红线标注出了基本要求:C/C++、Linux。

绿线标注的软性要求,一部分是不太容易量化的技能,比如精通多线程、独立设计经验等,一部分是产品业务相关的,比如音视频编解码、封装、流媒体、网络协议、视频业务系统等。

这则招聘信息中有两个优选条件,不过和我的知识、技能都不匹配。

一个程序员的知识、技能、经历,横看成岭侧成峰,角度很重要。

来看看新修改的技能与评价:

技能与评价

  • 9 年 C++ 开发经验,精通 C++,熟悉 STL

  • 可熟练在 Linux、嵌入式 Linux、Windows 等平台下进行开发

  • 熟悉常见的设计模式,有丰富的独立设计经验

  • 6 年视频业务开发经验,设计、开发过点播、直播流媒体处理系统,熟悉 FFMPEG、GStreamer 等开源框架

  • 精通网络通信,自己实现过标准协议 http 协议和私有 p2p 协议,熟悉 http/HLS/rtmp/p2p/rtsp 等各种流媒体协议

  • 热爱技术,著有《Qt on Android 核心编程》和《Qt Quick 核心编程》

和面向上一个招聘信息的内容又有了较大差异,是不是?

这次我改两个之前展示过的项目经历,方便比较不同。第一个:

2009.05~2011.09,跨平台视频点播系统

项目描述:(略)

** 软件环境:**Embedded Linux,Qt Embedded 4.5.1,Qt 4.5.1,C/C++ 硬件环境:全志 F20 芯片方案、PC

角色:项目经理、核心程序员

职责与工作内容: 
  1). 软件系统结构设计 
  2). 独立设计基于 Qt 的 EPG 框架  
  3). 设计实现音视频解码、解封装流程(参考 ffmpeg)    
4). 设计实现机顶盒软件的多线程模型 
  5). 团队组建与项目管理

业绩:

  1). 定制的多媒体框架保障了互联网机顶盒产品的视频处理效果,打开了电信市场,销量超过 30 万台。  
  2). 提供 Linux、Windows 版本客户端,为客服、运维、售后提供了强有力的支撑    
  3). 坚持自主实现关键的多媒体模块,形成了技术积累

这次我将重点放在了多媒体、设计等方面,与前面那份有了很大不同。

再来看文章最前面提到过的一个互联网视频卡顿的项目经验,新版本如下:

2013.11~2014.06,互联网视频卡顿优化

项目描述:

智能机顶盒上的视频聚合客户端,在播放视频时,高峰时段或热点视频,经常卡顿。针对此问题,进行优化,以使能够对用户提供流畅的观看体验

职责与工作内容:

  1). 作为系统设计,选择技术方案,设计加速与优化算法,设计系统结构。 
  2).C++ 实现标准 http 协议(含客户端和服务端)   

业绩:

  播放效果大幅度提升,卡顿投诉下降 80%。

和原来大不一样了。

需要特别提醒的是,简历优化是针对程序员知识、技能、经历进行的穿衣打扮,是从不同的视角呈现不同的侧面,可以用心琢磨,但万万不可造假。

检验优化效果

提供一个检验你简历优化水平的方法:

  • 将你钟意的企业和职位分为 A、B、C 三类,A 是最符合你目标的,B 与你最核心的诉求匹配,C 类呢可能抵触了你的某些核心价值观。

  • 针对 C 类公司的职位,测试你的简历优化技能,找三五家来练手,投递简历,简历过了就去面试,攒面试经验。

  • C 类之后进行 B 类,最后是 A 类。

这样的过程,能保证你先练简历和面试技术,然后以最好的状态走向你最心仪的公司最钟意的职位。

如何提高简历投递成功率

根据前面的分析,要想提高简历投递的成功概率,遵循下面的流程将非常有帮助:

  1. 梳理知识、技能、经历并记录在案,形成基础简历

  2. 确立求职目标

  3. 筛选招聘信息,选择匹配自己目标的公司和职位

  4. 针对每个招聘信息进行分析,提取关键词

  5. 根据关键词,结合基础简历,优化技能描述和项目经验,生成一份有针对性的简历

根据我自己的经验,一天可能只能完成 3 份左右的简历投递。因为,针对每一个职位生成一份有针对性的简历,可能会花费 1 到 2 个小时时间,有时甚至更长。不过,花再多的时间都是值得的,因为这种优化将大大提高你简历通过的概率。