敏捷开发和最小化功能组合的好处是能持续得到客户反馈,快速迭代,防止无用程序的产生。但是随着时间的推移,如果开发人员不注意,那些为早期客户编 写的程序会变得笨拙不堪,难以维护,无法扩展。你最终会讽刺的得到和敏捷方法完全相反的结果。而且问题的严重程度会随着公司的壮大呈指数级增长。合理的解决方案是什么?把产品“重构重写”。
对于处于快速变换的市场中的一个公司,这通常是走向灭亡的开始。
看似很合理
我刚好和一位朋友在加州的Palo Alto共进午餐,他是一个科技公司的创始人,现在出任董事会‘竹席’。几年前他聘请了一位职业经理做CEO。我询问他工作做的如何(“非常好,谢谢你的关 心,五年来,公司现在的市值已经达到5千万美元”),但他却想跟我谈一个在他脑子里想了很久的问题。“随着公司的壮大成长,我们对市场变化和客户反馈的反 应越来越迟钝。虽然现在我们的营业收入看起来还不错,但如果我们不能使公司的产品平台跟上客户需求的快速变化,一两年内我们就可能完蛋。我们的CEO没有 技术背景,但他也为公司不能开发出他想要的一些新功能和平台(Facebook,iPhone,Android等)而沮丧。在最近的一次董事会会议上,我 们主管技术的副总裁指出问题的根源在于‘我们的程序积累了太多的技术债务‘,程序实在是糟透了,我们现在根本没法处理。他告诉董事会,如果想在其上做我们 想要的修改,那只能重写这个产品。”我的朋友补充道,“这听起来很合理,所以CEO打算批准这个计划。”
举枪自杀
“那么董事会在听到这种鲁莽的计划后没有做任何反应吗?”我问道。“没有,”朋友回答道,忧郁的摇摇脑袋,“董事会成员都感觉这像个好主意。”
经过更详细的询问后,我了解到他们的已经膨胀巨大的代码库中还保留着公司早期在拓荒阶段为客户开发的代码遗迹。当初针对客户的产品技术设计对于公司当前所面对的新平台的扩展任务来说并不是正确的设计。
我提醒我的这位朋友,我从来没有做过技术管理,所以任何我给他的建议都是来自于经历过这种事情的他人。
引诱非技术出身的CEO的美妙海妖歌声
CEO在其职业生涯中至少会遇到一次这样的“重写”问题。如果他是被请来替代技术创始CEO的,那这个决策似乎很好定 —— 只需要对比一下负责技术的副总裁提供的重写(短期)进度计划和保留老代码、增加新功能(长期)的进度计划就行了。而事实上,这是个愚蠢的决定。技术团队也 许会知道使用旧程序的困难和问题所在,但不会知道如果重写代码库将会面对多少的困难和问题。
曾经经历过重写噩梦或理解程序的复杂性的CEO会知道,没有最初的技术开发团队,重犯以前曾经犯过的错误的几率会非常的高。加之会引入以前不曾犯过的错误,根据墨菲法则,不受约束的乐观主义会使1年期的重写计划变成数年。
我的观点是,CEO和主管技术的副总裁混淆了因果。客户并不要求新的程序。他们要的是新的功能和平台 —— 在当前。他们不太关心这 些功能是由一堆糊涂代码、还是由外星飞船、还是由一个新产品提供的。当你在代码重写的过程中,那些不痴迷于架构血统纯度的竞争对手会扩展他们的功能、平 台,拉拢客户、增加市场份额。这种目前就增加这些功能、还是一两年后再增加这些功能之间的区别代表着收入增长、还是被淘汰出局两种境况之间的区别。
谁想要老的产品
也许这着手搞程序重写最危险的副作用就是当你对旧的程序宣告死亡时却没有可替代的产品存在。当副总裁和CEO宣告公司将来要采用新的程序时,谁还会 去重视这充满问题的旧程序呢?当管理者说出“重写”这个词时,老的程序就死掉了。这后果就是,CEO没有退路可走。如果技术副总裁的开发进程最终是花了4 年时间,而不是设想的1年,那么在这几年期间对于系统新功能的增加不会有任何的进展。
这是一种预测的失败
我认为这看起来像是技术副总裁蓝景设计上的失败 —— 再加之没有代码重写经历的CEO推波助澜 —— 再经过想不出具有建设性的方案的董事会们的搅和。
给朋友的建议?指出市场的快速变化和竞争性,指出这种动作会使公司致命。公司在前进道路上的探索不应该在时间对于市场至关重要的情况下、在客户的需求快速转换的情况下对代码库进行重写。重写是在竞争周期比较长的市场条件下才可行。
我建议他应该在董事会会议上把这些情况陈列清楚。要求CEO详细列出什么时候需要什么样的功能和平台特征,用什么样的手段对进度计划管理的风险进行 控制。弄清楚这种完全不同的技术方案是否真的可行。(是否可以只重构目前需要追加新功能的部分模块?在新的代码库上开发要求的新平台系统?启动一个独立的 分支工作团队来开发新平台?等等)
原文链接:http://steveblank.com/2011/01/25/startup-suicide-%E2%80%93-rewriting-the-code/
分享到:
相关推荐
Git:Git高级特性:重写历史.docx
在微信小程序开发中,"重写App、重写Page与自定义分享"是常见的需求,它们涉及到小程序的基础架构和用户体验优化。以下将详细介绍这些概念及其应用。 **重写App** `App`是微信小程序的全局应用程序对象,它包含了...
【标题】中的“蓝色小程序网站pbootcms模板-小程序电商软件开发公司网站源码(pc+wap)”表明这是一个基于PbootCMS内容管理系统构建的网站模板,特别适用于小程序电商软件开发公司的在线展示。该模板采用蓝色为主...
"海地加密狗重写程序"是指针对特定的海地设计软件的加密狗进行修复或更新的工具,主要服务于CAD(计算机辅助设计)用户。海地2006是一款流行的CAD软件,其加密狗可能因为各种原因如烧录错误、损坏或过时,需要进行...
计算机后端-Java-Java核心基础-第14章 面向对象06 02. 复习:重写与super.avi
计算机后端-Java-Java核心基础-第14章 面向对象06 10. 多态性练习:重写方法.avi
ffmpeg 重写tutorial01程序--将一个视频文件解码输出ppm文件或bmp文件. 原文链接:http://dranger.com/ffmpeg/tutorial01.html 这个链接是一个很好的FFmpeg入门教程,但原文中的代码随着FFmpeg版本不断更新,部分...
【标题】"pokket:重写新月现金,更名为Pokket" 涉及的知识点主要集中在软件开发和项目重构上。这个项目是将原有的“新月现金”(Crescent Cash)进行了一次彻底的重写,并赋予了新的名字——Pokket。在IT行业中,...
ASP.NET 是微软开发的一种用于构建动态网站、web应用程序和web服务的开源框架。在这个特定的压缩包中,我们关注的是UrlRewriter.NET,这是一个用于ASP.NET的URL重写库。URL重写是一种技术,它允许开发者改变用户在...
ASP.NET C# URL重写是Web开发中的一个重要概念,它涉及到网站的地址结构优化和搜索引擎友好性提升。在本文中,我们将深入探讨URL重写、地址重写、伪静态以及如何将ASP.NET C#应用程序中的动态页面转换为HTML,以提高...
软件开发工程师试题涵盖了软件开发的方方面面,包括 SQL 语句优化、Decoole 重写 SQL 语句、命名规则、类型转换、JSP 中的 ArrayList 显示、beam、Home、Romate 的概念、Javabean 与 EJB 的区别、SESS’on bean 与 ...
URL重写是通过服务器配置或者应用程序内部处理,将用户请求的动态URL转换为看似静态的URL。这个过程并不会改变实际的请求处理逻辑,只是对外展示的URL形式发生了变化。 四、jsp动态转静态URL重写实现 1. 使用...
ASP.NET C# URL重写和无扩展名URL重写是两个关键的Web开发技术,用于改进网站的用户体验和搜索引擎优化(SEO)。它们涉及到对应用程序内部请求处理的方式,使得用户可以使用更加友好、易于记忆的URL,同时保持后端...
3. **软件重写**:讨论软件重写的目的,如提高效率、修复bug、增强兼容性、引入新功能等。 4. **编程接口**:可能涉及ECU的通信协议,如CAN总线、OBD-II等,以及如何编写代码与之交互。 5. **摩托车技术**:简述摩托...
URL重写是Web开发中的一种技术,主要用于优化和管理网站的URL结构,使其更符合搜索引擎优化(SEO)标准,提高用户体验,并便于服务器管理和应用程序处理。这个技术主要涉及到服务器配置、HTTP请求处理以及URL路径与...
总的来说,重写“heart”程序是一个融合了技术回顾、现代化编程实践和软件工程的过程。通过这个项目,开发者不仅可以提升自己的编程技能,还能深入理解代码的演变历程,以及不同编程环境和语言之间的差异。尽管我们...
这种技术主要通过两种方式实现:IIS服务器层面的URL重写和应用程序层面的URL重写。 1. **IIS URL重写模块**:IIS(Internet Information Services)作为Windows操作系统中的Web服务器,内置了URL重写模块。开发者...
如果配置不正确,可能导致应用程序无法启动或重写规则不起作用。确保正确添加 `<httpModules>` 和相应的 `<add>` 元素,指定模块的类型。 2. **规则匹配问题**:编写重写规则时,可能由于正则表达式错误或者规则...
Java 继承是面向对象编程中的一个核心概念,它允许一个类(子类或派生类)从另一个类(父类或基类)继承特性,从而实现代码的复用和扩展。...在实际开发中,合理地利用这些特性,能有效提升软件的质量和效率。
本安装程序专为启用IIS的URL重写功能而设计,旨在提升网站的性能和用户体验。 URL重写是通过IIS URL Rewrite模块实现的,这是一个可选组件,需要手动安装。这个模块提供了基于规则的URL重写引擎,可以将不友好的或...