`
乡村里的一条土狗
  • 浏览: 70313 次
  • 性别: Icon_minigender_1
  • 来自: 北京
最近访客 更多访客>>
文章分类
社区版块
存档分类
最新评论

编码混乱是技术上的债务吗?

阅读更多

“技术债务(technical debt)”这个词是由Ward Cunningham 发明的,用来描述为了在最后期限前实现某个项目任务而让开发团队做某种技术上的妥协。

这里有两篇博客文章,Uncle Bob 和 Martin Fowler 分别在里面描述了几乎所有项目都可能会遇到的各种技术债务。

A Mess is not a Technical Debt 这篇博客里, Uncle Bob 评论说,做出妥协是实现有最后期限目标的必要的手段。但是他区分妥协与否的方法只是纯粹从代码的粗心与否来考虑:

编码混乱并不是一种债务。编码混乱就是编码混乱。技术债务的产生是由现实的工程约束造成的。这是有风险的,但却是值得去做的。而程序员让编码混乱的行为永远是不理智的,它永远都是因为懒惰和不专业造成的,而且将来你也永远还不清这种债务。混乱永远都是一种错误 …

你承担的技术债务越多,你就应该越发自律。你应该做更多的测试,更多的结对编程,更多的重构。技术债务并不是你制造代码混乱的通行证。技术债务实际 上是要求你更清晰的代码 … 当你决定去欠下技术债务的时候,你最好能确保你的代码保持清晰易懂。保持系统的清晰易懂是你将来偿还债务的唯一途径 …

Technical Debt Quadrant 这篇博客里, Martin Fowler 认为编码混乱就是一种技术债务,是程序员在不经意间犯下的错误。Martin Fowler 接着描述了四种类型的技术债务:故意的/大意的,故意的/谨慎的,非故意的/大意的,以及非故意的/谨慎的:

做这些区分的目的不在于判断它是否是债务,而是判断是思虑过的还是粗心的 …

不仅仅谨慎产生的债务和大意产生的债务有区别,考虑过的债务和非有意的债务更要有区别。谨慎思考过的债务的例子就是”故意的债务“,因为团队已经知 道他们将会欠下债务,他们会考虑是提前发布一个不成熟的版本会得的利益多还是放弃这次发布产生的代价大。一个团队如果没有反复思考他们的设计,那他们就会 欠下粗心大意产生的债务,他们甚至没有意识到自己已经陷入了无法自拔的债务泥潭里。

注意到,有一种特殊的债务既是既是大意的又是思考过的:

经常会有这种情况出现,一个项目你干了一年后才明白你实际应该采用何种的设计架构。也许我们应该这样计划项目:花一年的时间去开发它,然后扔掉重建,但没人会认同这种做法。除了此时你会明白什么的设计才是你应该采取的设计外,你还要明白,这就是一个非有意产生的债务。

你是否也认为混乱的编码、快速但质量低下的程序实现是某种形式上的技术债务呢?或者,你 认为这些只是由于技术水平低下造成的,完全可以避免,即使是在有最后期限的情况下?(外刊IT评论 )

12
5
分享到:
评论
3 楼 对酒当歌,人生几何 2009-11-04  
欠债总比被人骂好吧。我遇到的都是赶任务第一,代码质量是排最后的。不管用什么方法,越快实现越好。这样才会被别人赏识。至少我遇到的长官是如此的。
2 楼 tianmo2008 2009-10-30  
时间决定一切,
真心喜欢编程的人,肯定都希望自己写出来的代码能让人称赞,但在没完没了的加班状态下,
代码的质量,只能根据写代码人的经验来定,想从美学的角度来欣赏一下,空谈..
1 楼 黑暗浪子 2009-10-28  
做任何事情都有一个渐进明细的过程,因此有时候早期的一些错误认知是需要花代价来修正的。我认为没有“债务”的软件产品和项目是不可能存在于这个世界上的。

相关推荐

    走出软件作坊电子书下载

    在软件行业中,“作坊式”开发往往指的是缺乏规范、不注重流程、项目管理混乱、代码质量低下、技术债务积累严重等现象。这种模式虽然可能在短期内满足了快速交付的需求,但长期来看,会导致软件系统的维护成本极高,...

    人月神话(程序员的神话)

    5. **技术债务**:书中虽然没有直接使用这个术语,但布鲁克斯讨论了快速交付可能带来的长期后果,即为了短期目标牺牲长期的可维护性和扩展性,这正是现代所说的“技术债务”。 6. **管理者的角色**:布鲁克斯提出...

    PHPVisualDebt该工具为源代码提供静态分析遵循最佳的QDD做法

    此外,它还会查找未使用的变量和常量,这些都是可能导致混乱和浪费内存的常见问题。 除了基本的代码质量检查,PHPVisualDebt还关注代码的可读性和一致性。它会检查代码是否符合PSR...

    退伙契约书.zip

    7. PDF转换:为了防止格式混乱,通常会将最终版本的契约书转换成PDF,确保在不同设备上查看时保持一致的布局。 在处理过程中,IT专业人员还需注意数据隐私和合规性,确保所有操作符合相关法律法规,特别是数据保护...

    <<人月神话>> <<manmonth>>精典软件工程管理丛书

    《人month》也探讨了技术债务的概念,虽然这个词在布鲁克斯的时代尚未出现,但他的观点预示了这个概念:为了短期进度牺牲质量,未来可能会付出更大的代价去修复。因此,他主张在项目初期就应该注重质量,避免技术...

    人月神话(pdf)

    6. **技术债务**:虽然这个词在布鲁克斯的时代还没有被广泛使用,但他指出了快速开发和短期解决方案可能导致长期的技术问题和维护负担。 7. **软件架构**:书中还涉及了软件架构设计的重要性,良好的架构可以支撑...

    重构-改善既有代码的设计

    这种做法可以有效地避免“技术债务”的累积,使得代码更加清晰、易于理解和维护。 **2. 重构的重要性** 随着项目的推进,代码库会逐渐变得庞大且复杂,这往往导致后续的开发工作变得更加困难。重构能够帮助团队...

    PHP代码书写规范

    通过标准化,可以促进代码的共享和复用,新人能更快地融入团队,避免因个人习惯造成的技术债务。此外,标准化允许局部改进,并且鼓励团队共同讨论和优化代码风格。 2. **命名规范** - **文件夹命名**:文件夹名称...

    Java极限编程.part02.rar

    - **技术债务**:如果不妥善处理重构,可能会积累技术债务,影响长期维护。 5. **成功案例** - 许多大型公司,如Craigslist和eBay,都曾成功实施过XP,显著提高了开发效率和软件质量。 总的来说,Java极限编程是...

    Writing Clean Code

    通过这些实践,程序员能够写出更易于理解、维护和扩展的代码,提升整个团队的生产力,同时降低未来可能出现的技术债务。《编写干净的代码》这本书深入探讨了这些主题,是C语言程序员不可或缺的参考资料。

    2005年上半年信息系统项目管理师真题(案例分析)

    **可能的后果:** 如果不遵循正式的变更管理流程,项目可能会面临不可预见的技术债务,导致后期修复成本急剧上升。此外,未经验证的变更可能引入新的错误,影响系统的稳定性和安全性。更严重的是,这种行为可能会...

    12个最重要的J2EE最佳实践

    综上所述,J2EE开发不仅仅是编码,它涉及从架构设计、测试、安全、性能优化到团队管理等多个方面。遵循上述最佳实践,可以显著提升J2EE应用的质量和效率,为用户提供更加稳定、安全、高效的软件产品。

    Java程序员应该遵守的10条纪律

    这10条守则是Java程序员在编程生涯中应时刻铭记的准则,遵循它们将有助于提升代码质量和团队协作效率,减少潜在的技术债务,避免灾难性的后果。同时,这些守则也是Java程序员在面试和职业生涯发展中的重要参考依据。

    互联网JAVA开发规范

    然而,在实际开发过程中,往往会遇到各种不规范的情况,这些问题可能会导致后续维护困难,甚至引发不必要的技术债务。因此,建立一套统一且明确的开发规范显得尤为重要。 #### 目标 本规范旨在为所有参与项目的...

    集中式财务管理软件操作培训XXXX4.pptx

    - **往来单位定义**:往来单位是指企业发生经济往来的其他实体,如供应商和客户,需要定义以便跟踪和管理相应的债权债务。 4. **日常业务处理**: - **总账**:包括制单、审核、记账等步骤,这些都是财务周期中的...

    联想软件(武汉)设计中心 C# 开发规范

    - 定期进行代码重构,以保持代码结构清晰,避免“技术债务”。 总的来说,联想软件(武汉)设计中心的C#开发规范不仅关注代码的细节,也强调代码的可读性、可维护性和团队协作。通过遵循这些规范,开发者可以编写出...

    Java编程31条规则

    - **知识点**:在技术领域,持续学习和适应新技术是必不可少的。 - **实践意义**:不断学习新的编程语言、框架和技术,可以帮助开发者跟上行业的发展,提高个人竞争力。 #### 规则31:资源推荐 - **知识点**:利用...

    The-Wasteland:除了完全的、无懈可击的狗屎之外,没有什么能超越这一点。 点击风险自负

    在IT行业中,编程语言是构建数字...综上所述,尽管"The-Wasteland"可能代表了一片编程混乱,但通过遵循良好的编程习惯,利用合适的工具和技术,我们可以避免陷入这样的境地,构建出高效、整洁且易于维护的Java项目。

Global site tag (gtag.js) - Google Analytics