APP下载

程序员的技术负债怎么还?

消息来源:baojiabao.com 作者: 发布时间:2024-06-15

报价宝综合消息程序员的技术负债怎么还?

技术负债就好比修改和扩充套件软件系统,每当新增新功能时,需要付出的额外努力就好像是债务利息一样。那么身为技术开发者,该如何偿还技术负债?

作者 | Martin Fowler

译者 | 弯月,责编 | 郭芮

出品 | CSDN(ID:CSDNnews)

以下为译文:

软件系统常常建立在内部质量有缺陷的程式码之上,因此比理想情况下更难修改和扩充套件系统。技术负债是Ward Cunningham提出的一个比喻,形容这个问题就像金融债务一样,新增新功能时,需要付出的额外努力就好像债务利息。

假设我的程式码库中有一个混乱的模组结构。此时,我需要新增一个新功能。如果这个模组结构清晰,那么我只需要4天时间就可以新增好这个功能,但是如今这个模组的结构很混乱,所以我需要6天时间。多出来的这两天就是债务利息。

关于债务的这个比喻最吸引我的地方在于,它让我思考如何处理这个问题。假设我可能需要5天时间来清理这个模组化的结构,改好不健全的功能,这就相当于支付本金。如果只有这个功能需要用到这个模组,那么就得不偿失,因为我总共需要9天时间,如果我继续容忍这个模组的话只需要6天。然而,如果有两个相似的功能都用到了这个模组,那么我肯定会首先改好这个模组来加快速度。

如此说来,听起来这是个简单的数字问题,凡是有电子表格的经理都应该能够做出很好的选择。遗憾的是,我们并不能很好地衡量我们的生产力,因此这些成本都无法客观地衡量。我们可以估算完成一个功能需要多长时间,我们需要估算做新功能的时间(在改好模组后的情况下),以及改好这个模组的时间。然而,我们的估算的准确性非常低。

鉴于此,通常我们的做法是:背负着负债继续做新功能,并逐步支付本金。在做第一个功能的时候,我会花额外的几天时间来修复一些不健全的功能。这可以将未来的利息降低到一天。虽然这之后我们仍然需要花费额外的时间,但是这些程式码附带的负债会降低。这种逐步改进的好处在于,如果我们频繁地改动某个有待修改的负债,那么就证明这些程式码正是最需要被清理的区域。

这种用支付利息代替支付本金的方式,可以帮助我们决定优先解决哪个负债。假设有一个非常可怕的程式码库,修改这个程式码库简直就是一个噩梦,如果我没有必要动这个程式码库,那就不是个问题。只有当我用到这部分软件时,才需要支付利息(这是这个比喻与金融上的负债不同的地方,因为金融的利息支付是由时间决定的)。因此,我们可以不必理会那些稳定的负债。相比之下,活跃度非常高的区域需要非常及时地修改,我们应该采取零容忍的态度,因为这部分债务的利息非常高。这一点非常重要,因为开发人员往往只知道一味地更改程式码,却不关注内部质量的时候,这些负债将不可避免地积累起来——程式码变更越多,风险就越大。

有时,这种债务的比喻也可以判断是否应该忽略内部质量。关键在于我们需要付出时间和精力才能阻止负债的积累。如果有些新功能非常迫切,那么也许我们不得不继续背负债务,只有等到将来再来处理这笔负债。

然而,大多数时候我们的这种分析做得都不好。另一方面,技术负债的影响非常快,会迅速拖慢新功能开发的速度。不断积累负债的团队最终都会被自己的债务搞得一塌糊涂,大幅延迟交付,所以还不如趁早努力提高内部的质量。这个比喻往往会让人误解,因为这种发展趋势与金融贷款并不完全相同。

人们经常会争论是否应该将不同种类的质量问题视为债务。我觉得我们应该考虑这些债务是有意造成的,还是一时不小心造成的。

本文为 CSDN 翻译,转载请注明来源出处。

【END】

6月29-30日,2019以太坊技术及应用大会特邀以太坊创始人V神与以太坊基金会核心成员,以及海内外知名专家齐聚北京,聚焦前沿技术,把握时代机遇,深耕行业应用,共话以太坊2.0新生态。扫码即享优惠购票!

你点的每个“在看”,我都认真当成了喜欢

2020-01-12 18:51:00

相关文章