时隔16年Jeff Barr重返10.23-25 QCon上海站,带你看透AI如何重塑软件开发! 了解详情
写点什么

用金钱计算技术债务

  • 2010-03-31
  • 本文字数:1206 字

    阅读完需:约 4 分钟

很多敏捷团队都能认识到技术债务相关的罪状。就跟财务上的负债一样,技术债务也会产生利息。要支付这些利息,就要付出额外努力维护和改进正在“腐化”或基础并不牢固的软件。诸多敏捷人士推荐尽早偿还技术债务。然而,大多数敏捷团队无法成功以金钱的方式计算技术债务,因此无法得到有价值的深入理解和思考。

一旦有了与技术债务直接相关的金钱数目,关于软件的多种复杂而麻烦的问题就能得以回答。 Israel Gat 提出:除非对于技术债务有一个量化的账单,否则团队都会忽略其重要性,软件会因此而逐渐腐化,无法补救

当债务达到一定程度之后,就没有什么好的补救方法了。代码质量非常糟糕,这时要修复任何部分都会造成伤害,不管修复哪里似乎都会破坏其他某些部分代码。

他还提到了以金钱方式计算技术债务的需要,并使用收支平衡表展示出其作为债务的一面

在 Israel 看来,以金钱方式计算技术债务有如下好处:

  1. 能够告诉团队何时停止开发,开始重构——当技术债务达到一定程度后(比如每行代码 25 美分),就要暂停开发新功能。团队进入重构过程,除非债务得以偿还,否则不加入任何功能。
  2. 软件的客户对于软件的风险得以了解——Israel 认为这符合敏捷宣言中的一项:“客户协作胜过合同谈判”。
  3. 风险投资者能够以此做出投资决策——VC 们可以以此判断向某项软件产品中投入资金是否理智。
  4. 有助于判断软件的支付能力——软件在其生命周期的演化过程中,与之伴随有开发和维护活动,以金钱方式计算技术债务能够有助于回答与这些活动相关的支付能力问题。
  5. 有助于人们在重构和重写这二者之间做出选择——将技术债务与其他重要因素联合起来,能帮助人们判断是否要重新开始。
  6. 有助于定义限额——一旦金钱上的限额定义出来之后,就能帮助 CxO 等利益干系人做出成熟的决策。

那么,有哪些有效的方式可以用来将技术债务以金钱衡量呢?

使用 Sonar 中的技术债务插件是一种方式。在 Sonar 的实时站点上,已经有了对于多个项目的技术债务分析。要计算成本,首先要使用下面的方式找出债务:

  • 债务(以人天计算)={修复重复部分的成本+修复违规的成本+为公共 API 做注释的成本+修复未发现的复杂性的成本+带入低于阈值复杂性的成本+在包的层面上切断生命周期的成本}

在上面各种违规情况中,对于每个小时的成本有个默认值。比如:

  • 修复重复部分的成本={修复 1 个部分的成本 * 重复的部分}

现在,比如默认的“修复重复部分的成本”为 2 个小时。假设每个开发人员每天的成本是 500 美元,一天有 8 个小时,那么修复一个重复部分就要花费 125 美元。与之类似,就可以做出针对各种违规情况的金钱分析,并可以计算出最终的技术债务总和。

因此,以金钱方式计算技术债务能够让人们深入理解与软件相关的潜在成本。对于所有希望监控技术债务成本并将其保持在一定限额内的敏捷团队来说,这很关键。这么做有助于创造一个易于维护和改进的软件产品,同时让 VC 有信心投资,让客户有信心买单。

查看英文原文: Monetizing the Technical Dept

2010-03-31 00:002248
用户头像

发布了 479 篇内容, 共 178.6 次阅读, 收获喜欢 53 次。

关注

评论

发布
暂无评论
发现更多内容

Chrome浏览器控制台支持中文

FunTester

chrome 浏览器 控制台 FunTester 中文

一文教你如何落地spring cloud alibaba企业级架构

小鲍侃java

后端 引航计划

送你一个Python 数据排序的好方法

华为云开发者联盟

Python 数据分析 数据排序

多租户是什么意思?怎么理解?

行云管家

云计算 运维 SaaS

滴滴 x StarRocks:极速多维分析创造更大的业务价值

StarRocks

数据库 数据分析 滴滴 Clickhouse StarRocks

一张图读懂Z-ONE Studio Lite

SOA开发者

从敏捷开发到全自动开发,加速实现企业数字化转型

飞算JavaAI开发助手

Linux用户/用户组编辑

在即

9月日更

Python代码阅读(第28篇):计算列表中位数

Felix

Python 编程 Code Programing 阅读代码

华为云GaussDB(for MySQL)2.0全新升级,三大技术大揭秘

华为云开发者联盟

数据库 云原生 GaussDB GaussDB(for MySQL) 华为全联接2021

一张图读懂Z-ONE Studio Lite

SOA开发者平台

一张图读懂Z-ONE Digital Car

SOA开发者平台

Redis可观测最佳实践,5大关键指标最全解析!

观测云

redis

Flutter 对状态管理的认知与思考

小呆呆666

flutter ios android 大前端 dart

【墨天轮专访第五期】偶数科技常雷:创新改变世界,深耕云数据仓库

墨天轮

数据库 国产数据库

你知道怎么离线安装全局 node 模块吗?

编程三昧

大前端 npm Node 离线包 9月日更

如何实现一款毫秒级实时数据分析引擎

Shopee技术团队

大数据 数据分析 后端 HBase

等保是强制的吗?企业不办等保有啥处罚?

行云管家

网络安全 等保 等保2.0

华为云开天aPaaS 上线,服务千万开发者,使能行业场景化创新

华为云开发者联盟

华为云 企业应用 开天aPaaS aPaaS 华为云生态

浏览器测试的三大挑战及解决方案【译】

FunTester

软件测试 测试 FunTester 兼容性测试 浏览器测试

“智感超清”之HDR技术落地实践

百度开发者中心

最佳实践 音视频

Prometheus 2.27.0 新特性

耳东@Erdong

release Prometheus 9月日更

Intel要跟华硕等OEM品牌推出DG2显卡?官方:消息不属实

科技新消息

考试系统高并发试卷存储设计方案

Imaginary

Java变异出现错误:No enclosing instance of type XXX is accessible

华为云开发者联盟

Java

【存储专栏】打破K/V存储的性能瓶颈

趣链科技

区块链 存储

全网通用Python点赞器(俗称刷分机器),想知道原理吗?看完本文你自己也能写个

梦想橡皮擦

9月日更

一张图读懂Z-ONE Digital Car

SOA开发者

Go 中五个常见错误

baiyutang

golang 9月日更

Intel高管披露Arc显卡合作厂商?官方否认

科技新消息

书单 | 带你轻松度假的10本好书!

博文视点Broadview

用金钱计算技术债务_研发效能_Vikas Hazrati_InfoQ精选文章