互联网公司和软件工程那些事

开发 后端
2004年,我大学毕业到新浪时,正好参与了一个大型的互联网项目——新浪教育频道见习就业项目。进度是由项目经理控制的,光是需求分析报告叠起来有一个iPhone侧面高。过程还算正规,有ER图,有数据结构表,还有界面示意图。

关于软件工程,我一直有一些零散的想法,正好@技术人攻略 这期聊这个话题,于是顺手写了这篇「散」文。

关于延期

2004年,我大学毕业到新浪时,正好参与了一个大型的互联网项目——新浪教育频道见习就业项目。进度是由项目经理控制的,光是需求分析报告叠起来有一个iPhone侧面高。过程还算正规,有ER图,有数据结构表,还有界面示意图。从项目开始我们就天天加班到晚上四五点,回去睡个觉,早上9点回来接着干。还记得我和伟平半夜3点出去买烟,回来看见前端的妹子一边哭一边嵌页面。***项目还是延期了蛮久。

出于对加班的恐惧,那时候我就对软件工程产生了兴趣,然后读了大量关于软件工程的书,统一过程、敏捷开发、极限编程以及***期限、人月神话这些周边。我试图弄懂,为什么需求和开发之间,会有如此之大的鸿沟,以至于它能成为一门独立学科。

这个思索持续了多年,我一直没有找到合适的答案,直到2009年我回到新浪,担任新浪云计算产品经理。

SinaAppEngine项目8月立项,11月上线***个版本,整体进度延迟3天(这就是为什么它是11月3日上线的),当时我们就五六个人。我在新浪云负责的***一个大项目——新浪云商店***期上线,没有进度延迟。

这让我发现,延期最核心的问题其实并不在于过程,而在于需求。作为一个曾经开发过亿访问量系统的产品经理,我可以异常精准的控制需求和进度。我们在需求分解时,可以在技术实现级别讨论时间表。最终我们的时间表可以精准在小时级别,误差在天。这招屡试不爽,从快简历到JobDeer.com,我们的进度延期都最多几天。

关于质量

再来说质量的控制。

如何提升软质量

程序员有一个习惯,就是把自己的高标准拿去要求别的人。所以我们会发明各种高效但是一点都不易用的框架,觉得——如果连这个都不明白,还当什么程序员。

我一直都是这么想的,但当我08年自己开工作室的时候,我发现我没法招到技术特别好的人,我们新招的同学甚至搞不明白面向对象。

于是后来我写了LazyPHP框架,这是一个用面向过程封装面向对象的框架。整个框架20个函数,搞定一切。它只有一个目标,让不懂面向对象的人,也可以写出强壮的Web程序。大体来说,它做到了。

再说一件事情。在设计SAE的时候,我们有一个最常讨论的话题,就是如何让那些写出不良代码的程序员进行自我修正。后来我们采用了云豆和配额两个方式来进行软性限制。现在SAE上访问量特别大的应用都优化得特别好。

如何提升硬质量

我从来不相信软件是什么艺术,艺术从来不会Done is better than perfect。所以有些核心的质量指标是必须的,比如单元测试,比如编码规则,比如常规安全检查。而这些东西,不应该作为圣经天天念,而应该简单粗暴的做到代码发布系统里边,不遵守就提交不了的代码。

关于软件工程

坦白的说,我觉得「软件工程」这个名字过时了,那是软件时代的遗物,在互联网时代是很诡异的。软件不再是被定义好的大规模工程,分发到外包公司去做实现。它是产品不可分割的一部分,是受需求影响***最惨的部分。

需求分析,原来是软件工程的起点,现在已经由专门的产品团队来做了,这个决定创业公司生死存亡的东西,居然以前是程序员在做。user story,在没有用户画像、应用场景时也很容易失之千里。

我们需要一个新的,产品整体的工程化,以天为周期进行全产品流程迭代的过程。而我在这个方向找到的最接近的理论,是《精益创业》。它是精益开发在产品全流程的实现方法论。

我觉得,未来「产品工程」会替代「软件工程」。

大型互联网公司的技术团队会分成两类人,一类做私有云平台——提供通用技术能力(这部分前期可以用公有云),一类直接合并到业务团队做实现。

超大型项目,会被API分割成平台和应用,通过强隔离的方式有序生长;而以往那些依赖关系,也会在这个层面得到很好的解决。

大部分人不用关心系统,只需要关心自己的应用。

软件工程本身,则浴火重生,从一个面向过程式的管理,变成一个面向对象式的支撑环境(有点像对象容器)。

具体的东西,我没想太好,我就随便写写,您就顺便看看。

责任编辑:张伟 来源: Get社区
相关推荐

2018-09-29 14:59:06

互联网数据BAT

2018-08-23 09:06:18

互联网百度面试

2013-01-18 09:26:58

2015-11-17 09:09:56

2015-11-16 09:50:11

2015-03-09 09:47:37

互联网公司软件

2015-08-06 13:57:58

初创谎言ceo

2013-12-18 16:21:32

未来互联网移动互联网

2013-01-25 10:31:02

互联网公司移动互联网船票

2010-12-30 09:17:57

PHP程序

2013-08-08 10:19:22

2015-10-19 10:28:14

2015-09-09 14:24:14

2015-06-24 15:35:54

2018-12-17 08:59:38

2019-06-17 11:17:20

互联网中年人工作

2020-04-24 15:47:31

互联网公司裁员

2013-07-26 13:40:12

主密钥NSA

2020-02-06 16:08:46

互联网剧变企业的待见

2021-01-11 09:50:30

互联网公司面试
点赞
收藏

51CTO技术栈公众号