点击蓝色“程序猿DD”关注我

回复“资源”获取独家整理的学习资料!

>>阿里云8月最新优惠,点击查看<<

大厦新搬进来一家创业公司,老板红光满面地提着果篮上楼拜访,说是刚拿到了投资人的钱,正准备扩充团队大干一场。那个时候的他踌躇满志,顾盼生辉。当时我想,能在这个大环境下拿到投资的公司,做的产品应该是有前景的。

没想到几天后在电梯遇见时,却发现这位老板已经没有了往昔的风采,整天愁容满面。他在电梯看到我以后问道:“我记得你们是做技术媒体的吧,有个问题想请教一下。”

原来他烦心的症结在于:

我们公司拿到投资以后,人员配置到位还算及时,业务扩张的速度还是挺快的。没过多久我们技术团队的人就跟我说,现在业务发展势头比较好,现有的技术架构快扛不住了,得招些技术牛人来团队负责整体架构规划、升级。

我不是搞技术出身的,以前总是在各种论坛上听说阿里巴巴的 P8、P9 多牛逼,技术多厉害,我就想这种级别的程序员应该可以满足我们的需求吧。于是我用年薪百万的 offer 砸了个阿里新升的 P8 来我们团队做 CTO,可是现在问题不仅没得到解决,反而更复杂了。技术团队的人觉得他名不副实,他觉得我们找他来是打杂的,干得也不开心,两头乱。

我问他,你们觉得他哪里不好?

他只会写 Java,我们用 Go;

他只会搞后端,前端基本不懂;

他算法不太行,我们要做推荐;

他只会写 Web,我们要做 App;

他只晓得用开源工具,我们要造自己的轮子;

……

“那等于是他哪哪都不如你们意呗?”我问他。

对啊,我也没想到阿里 P8 这么水。

“可你一开始要招的不是可以给你们重构系统架构、偿还技术债的 CTO 吗?”

这……有啥区别吗?

“区别大了。你这又是要让前端后端都会,又是要精通各种编程语言,还要能搞移动开发,你这想要的是个全栈,而不是 CTO。哪有 CTO 干这些活儿的,你这是想让一个在大厂流水线上拧螺丝的人来给你把每个窟窿都堵上,不可能啊。”

合着我钱白花了呗?

“倒也不是白花了,BAT 这些大厂都有一套流程化的线上线下、开发管理机制,一般能升到 P8 的,碰到水货的可能性相对较小。你的问题是需求跟招聘方向不匹配,你要招的这是全栈工程师,人家大厂的技术专家是流水线作业,差别大着呢。你听我跟你分析分析。”

1大厂程序员:流水线上作业的螺丝工

软件工程作为一个行业,发展至今已经有超过 50 年的历史。软件开发在互联网的数次浪潮冲刷下,已经是一个非常完备的成熟行业。在一线互联网公司,比如硅谷的 Google、Facebook、Amazon,比如中国的阿里巴巴、百度、腾讯等,其软件开发已经是一个成体系的流水线式作业。

就以前文提到的阿里巴巴为例,作为国内最有代表性的互联网企业之一,阿里巴巴的软件开发已经形成规模化的效应,直接体现在软件开发的模式上就是一条完备的流水线式作业。

流程化、规范化是大厂软件开发最大的特点。一次完整的需求开发流程是这样的:1. 需求预审、评审;2. 概要设计与评审;3. 测试用例撰写与评审;4. 开发;5. 测试与 bug 修复;6. 发布;7. 版本总结 / 项目过程总结。在这个过程中,每个开发人员都各司其职,拧着各自负责的螺丝。

很多新人在加入技术团队后,通常会有一个资深的员工作为师兄帮助其更快地融入工作、掌握相应的技术。一般而言,在开始阶段新人的任务都是从简单的程序开始写起,比如迁移部分系统代码(从上游系统迁移到下游系统),做一些简单的小需求(如修改 bug,增加某一个字段等)。

这些需求看似简单,实则不然。因为哪怕涉及一行的改动,都需要进行大量的测试进行覆盖,很多人以为这些都该是测试去做,但实际上,测试往往只能进行黑盒测试,而且测试对于代码的了解程序一定不如开发,所以在这些细节上的测试都是由开发自己自测完成。因此,往往改动一行代码,开发就可能都会花上半天的时间用各种方法进行测试。

不仅是测试,阿里技术团队在 2016 年左右开始了一次大的组织架构调整,即把日常的运维工作交给研发做。原来的 PE(Production Engineer)要么转岗去做工具平台开发,要么作为运维专家做产品规划和设计,还有一部分无法适应的只能黯然离开。这是阿里运维从工具化到自动化最重要的一个过程。

规模化、流程化、自动化,这几个关键字放在一起,你第一眼可能想到的是生产车间,但在阿里巴巴,这是其技术团队多年沉淀下的一个行之有效的软件开发模式。

阿里巴巴相对而言是一家业务驱动的公司,项目以业务优先,对于团队来说其重要性不言而喻。在阿里巴巴,这是一个需要多人开发,团队协作的事情。对于那些研发人数动辄超万人的大型互联网公司,要前端就找前端,要后端就找后端,规模化以后要求的不是全才,而是专才。

规模越大的互联网公司,程序员干的事情反而越机械,在软件开发的流水线上做着增删查改的拧螺丝活儿,但这些人,在入职前可是通过了“面试造核弹”般的筛选才进来的。越是高级别的技术专家,出现水货的可能性也越小,同样,他也不可能成为一个小公司需要的全栈开发。什么都会一点的结果,就是什么都不精。

产品规模上去以后,各个模块复杂度都很大,全栈未必适合,规模上去以后势必也要拆分一些项目出来,由专人维护,全栈存在的意义不大。大公司讲究专人专岗,你就做好自己那点事就得了,就算你离职,找到替代你的人相对也比较容易。

“所以你想挖一个阿里的 P8 做你公司需要的全栈是不现实的,你就是把行癫挖过来这问题也解决不了啊。”

那小公司的技术咋整?

2小公司要的全栈开发

“人们一提起‘全栈开发工程师’,大家的印象肯定是:这号人啊,堪称大神!会很多技术,前端后端都精通,不掌握七八种语言都不好意思出来打招呼,热点技术名词全都知道,也都会点儿,跟谁都能谈笑风生。”

对对对,我们要的就是这样的人!

“但是呢,全栈工程师更像是一个神话。每个人的精力都是有限的,你需要人家精通前后端,自己能写代码还能做测试搞运维,能写网站还要能写 App,你咋不上天呢?”

以上是一个全栈工程师应该掌握的并不详尽的技术栈,各位可以对照着看看自己离全栈有多远,再想想全栈工程师是梦想还是现实。这还是在不考虑技术更新换代就像智能手机的更换周期一样的现在,上图所示的技能表每年每层都会增加新的组件,每隔几年又会增加新的层。全栈,你全得过来吗?

全栈工程师,一定程度上更像金庸小说里的慕容复,刚出场时牛逼哄哄,什么都会,自带光环。可后来随着剧情(业务)的展开,逼格直线下降,被武林同道所笑话。

事实上,创业公司一般比较喜欢招全栈,这和创业公司的需求有关系,因为创业初期的公司可能需要一个人做几个人的活。另外,可能老板是技术出身,了解部门之间衔接所需要付出的巨大沟通成本,所以倾向于更少的沟通单位。

对于个人和公司,全栈的定义是不一样的,初期公司肯定是希望全栈的技术广度和深度刚好能满足公司业务要求,本质上只是想要个全干。但对于个人来说,大多数普通人的时间精力有限,很难真正在广度和深度都做到专业,如果只是为了满足公司需求点技能点的后果就是——项目发展起来之后公司有钱了,全栈差不多就该扫地出门了。

对于创业公司而言,为了压制成本,需要全栈完全能够理解。毕竟一个优秀的程序员也不便宜,能让一个人干两人甚至三人的活儿好像对于成本控制是个好办法。然而,显性的成本控制住了,隐性的成本呢?

“你想没想过,当你的项目到了关键时刻,比如要上线了,或者上线出 bug 了,这时候分分钟就是几十上百万的流水,而你的技术团队因为缺乏专人出问题了。你急急忙忙地去找你的全栈 CTO,他却说:稍等,我上 Stack Overflow 查下这是什么故障。你崩溃吗?”

呃……

”会上 Stack Overflow 的还算好的,他要是个面向百度编程的全栈,你就只有哭的份了。“

再进一步,一个比较复杂的项目,如果一个全栈走了,项目受到的影响会很大,你很难再招到一个完全匹配该项目的另一个全栈。我们见过太多创业公司因为技术团队关键人物离职直接导致项目失败的案例,你越是想省钱,越是省不下钱。

听你这么说,怎么觉得全栈就这么不堪入目呢?

”非也非也。你们这些当老板的,总是认为都是写代码,前端后端没什么区别,Java、Go 没什么两样,这本身就是最大的误解。全栈工程师一定是有其存在的意义的,但你如果想让全栈工程师把什么事儿都全干了,996 都没你这么狠的。全栈工程师也许是未来的一个发展趋势,但现在那些简历上写着全栈的程序员,大概率才是你们认为的水货。“

所以总结下来,他不是个水货 P8,我是个水货 CEO 喽?

“佛曰,不可说。”

我们开小店啦,新人9折券限量领取

留言交流不过瘾?添加微信:zyc_enjoy

根据指引加入各种主题讨论群

每日一问

今日问题

(留言说说你的答案吧,明日推文公布答案)

昨日答案:选A

除了图形B,其他图形都有黑色边框

除了图形C,其他图形都是方的

除了图形D,其他图形都是红的

除了图形E,其他图形都是大的

只有图形A集合了大部分特点,却没有任何一点与众不同,A才是与众不同的!

不为最先不耻最后,中庸之道亦在其中

(昨日问题可在昨日推文的文末查看)

推荐阅读

  • 你必须收藏的Github技巧

  • 开发部署提速8倍!这款IDE插件了解一下?

  • 攻破MySQL性能瓶颈必知的调优技巧

  • 如何模拟将CPU、IO打满?

  • Spring Cloud Alibaba 发布第一个正式版本,顺利完成孵化!

来星球聊聊技术人的斜杠生活


点一点“阅读原文”小惊喜在等你

百万年薪挖了个P8程序员,难道是“水货”?相关推荐

  1. 百万年薪挖了个P7程序员,难道是“水货”?

    前阵子,我的一个一起工作过的同事跟我吐槽,"他去年从大厂跳槽到了一家 C 轮创业公司担任技术 Leader,今天居然被老板通知试用期没通过!" 这个朋友在加入小厂之前,有过两段大厂 ...

  2. 年薪 170 万阿里 P8 程序员征婚上热搜,程序员婚恋观大曝光!

    整理 | 伍杏玲 出品 | 程序人生(ID:coder_life) 上个月,民政部公布,2018年中国单身成年人口已经超过2亿, 独居成年人口超过7700万. 前两天有一位阿里P8程序员决定告别这个& ...

  3. 花百万年薪从阿里挖了个 P8 程序员!难道是“水货”?

    点击"开发者技术前线",选择"星标????" 在看|星标|留言,  真爱 来源 | InfoQ  作者丨小智 编辑 | 可可 大厦新搬进来一家创业公司,老板红光 ...

  4. 公司花百万年薪从阿里挖了个P8程序员,竟然是“水货”?

    点击上方"码农突围",马上关注 这里是码农充电第一站,回复"666",获取一份专属大礼包 真爱,请设置"星标"或点个"在看&quo ...

  5. 毕业之后,这些年薪 50w+ 的 90 后程序员都经历了什么?纯水贴

    毕业之后,这些年薪 50w+ 的 90 后程序员都经历了什么? 即使是处于薪资链顶端的程序员,年薪(不含期权.股票等)超过 50 万,对他们而言也并不是一件容易事.就招聘平台 100offer 而言, ...

  6. 一线城市年薪四十万以上的程序员,真实状态是怎样的?

    日常生活中,我们的很大一部分工作是与程序员群体打交道,研究他们的工作生活状态和职业发展路径. 在外人眼中,程序员是一个既高薪又神秘的群体,比大多数岗位更容易在职业生涯的前几年收获高薪.然而真正接触这群 ...

  7. 俄罗斯、乌克兰程序员薪资大曝光!年薪普遍 15w+,女程序员比男程序员收入高?...

    整理 | 郑丽媛 出品 | CSDN(ID:CSDNnews) 提及对俄罗斯的认知,我们通常会从许多熟知的角度出发,如国土面积.最长铁路.重工业等,但似乎很少有人能对其 IT 技术侃侃而谈--相比西方 ...

  8. 转行学Java,如何才能成为年薪50万的Java程序员呢?

    作为炙手可热的薪资高的人才,Java程序员的薪资一直有目共睹.以武汉为例,根据权威机构统计,武汉Java开发人员的平均薪资是13.2k/月,这个工资远远高于武汉的平均工资水平,可以说是非常可观了.但比 ...

  9. 俄罗斯、乌克兰程序员薪资大曝光:年薪普遍 15w+,女程序员比男程序员收入高?

    整理 | 郑丽媛 出品 | CSDN(ID:CSDNnews) 提及对俄罗斯的认知,我们通常会从许多熟知的角度出发,如国土面积.最长铁路.重工业等,但似乎很少有人能对其 IT 技术侃侃而谈--相比西方 ...

最新文章

  1. sqlite3 解决并发读写冲突的问题
  2. css文字和背景色渐变色
  3. 倒排文件索引(Inverted File Index)的建立
  4. powershell 安装mvn_Maven 安装好之后,命令行执行 `mvn -v` 提示“'mvn' 不是内部或外部命令,也不是可运行的程序 或批处理文件。”...
  5. c++ 实现ping
  6. 花书+吴恩达深度学习(二三)结构化概率模型(贝叶斯网络、马尔可夫随机场)
  7. 如何把google日历添加到桌面
  8. Springboot毕设项目基于SpringBoot的个人理财系统ibx9hjava+VUE+Mybatis+Maven+Mysql+sprnig)
  9. python四则运算完整代码_2/20Python之四则运算
  10. java8 zoneid_java8之localDateTime, ZoneId, Instant使用
  11. 关于使用群晖系统创建音乐外链的研究
  12. html css animate,animate.css的使用方法
  13. 2021-01-09:Microsoft Word2019 提示:很抱歉此功能看似已中断,并需要修复。请使用Windows控制面板中的“程序和功能”选项修复Microsoft Office
  14. python面试自我介绍怎么介绍比较好_面试时三分钟自我介绍,需要注意哪些问题?...
  15. Mac 系统打开 word 显示全黑怎么处理
  16. 使用HTML5/CSS3五步快速制作便签贴特效
  17. BLE学习(1):蓝牙协议栈的介绍
  18. UltraISOPE 9.6.2.3059简体中文注册版/单文件版+软碟通
  19. [QGIS插件]通过GeoCat Bridge发布矢量数据到Geoserver
  20. 2021年中国耐火材料行业产业链分析:耐火材料行业发展稳中有升 [图]

热门文章

  1. linux c 获取时间戳
  2. python3 错误string indices must be integers 的解决方法
  3. Merkle Tree(梅克尔树)算法解析
  4. docker逃逸 从Play-with-Docker容器逃逸到Docker主机
  5. 读秦小波《设计模式之禅》 -- 工厂模式
  6. linux 内核与用户空间通信之netlink使用方法
  7. 取代INT 80 的sysenter/sy***it
  8. hypercall的实现机制与硬件虚拟化
  9. mysql 生产实践_mysql-主从复制
  10. Windows - Windows批处理