2天时间,聊今年最热的 Agent、上下文工程、AI 产品创新等话题。2025 年最后一场~ 了解详情
写点什么

成本会计会导致无价值的代码吗?

  • 2007-06-15
  • 本文字数:1143 字

    阅读完需:约 4 分钟

成本会计是分析项目货币价值的标准会计方法,它将项目的各部分分别对待并且鼓励进行局部优化。成本的局部优化意味着强调完成任务的时间,而使任务完成时间最小化的关注就意味着你没时间进行重构和其它完善工作,因为这类工作太浪费时间了。这就是“万源之源”,就是不做这些事的常见理由,即“老板没有给我足够的时间做这些事”。

Henrik Mårtensson 其博客中提到了约束理论(Theory of Constraints), 并说明产量会计(throughput accounting)是如何营造一个可以接受敏捷开发实践的环境的。他通过一个假想的例子来告诉我们:

假如有两个项目团队,A 团队和 B 团队。每个团队都一个项目经理,四个开发人员和三个测试人员。每个团队成员的薪水是€3,500/ 月,工作时间是 160 小时 / 月。项目经理的薪水是€4,000/ 月。两个团队的生产率都是 80 个故事点 / 星期。 在团队 A 中,开发人员都在拼命工作,但测试人员却有很多空闲时间,时常上网冲浪。在团队 B 中,却是另一种景象。测试人员刚好跟上开发步伐,所以开发人员降低了开发速度以免测试人员处理不完。在某一天,两个团队都发现了一个缺陷。这两个缺陷都需要一个开发人员花八小时来修复。那么,团队 A 和团队 B 的成本各是多少呢?

这是给读者的一个思考题:“发现一个缺陷时会怎样?”成本会计告诉我们,这两个团队修复这个缺陷的成本是一样多的。但是多想一会儿,你就会发现这其实只是一个假象:

在团队 A 中,一个开发者去修复这个缺陷时,会直接影响整个团队的生产率。而在团队 B 中,开发者有一定的空闲时间。他们能修复这个缺陷却不受太大影响,在整个团队生产率上可能根本没有什么影响。即使不详细说明,结果也很明显,对两个团队的影响是完成不同的。

那么,问题在哪?关键在于成本会计强调的是局部最优,而实际上我们需要全局最优。利用成本会计,我们营造了一种环境,在该环境下,我们不鼓励任何延长局部周期时间的行为。

简而言之,假如你把软件开发项目的每个组成部分都看作是与其它部分相互独立的部分,那么关注任务完成时间就变成非常重要的了。假如你关注任务完成时间,你就不会在一些琐事上浪费时间,例如重构、写单元测试,以及进行领域设计。就算你想做这些事,管理者也会督促你开始新的任务。

看看“约束理论”和精益生产(Lean Manufacturing)也没什么新鲜的: David J. Anderson 写了一本书,名为《软件工程的敏捷管理(Agile Management for Software Engineering: Applying the Theory of Constraints for Business Results)》,而 Mary 和 Tom Poppendieck 因其在精益软件开发方面的工作而闻名。随着这个社区的成长,我们将看到从这两个领域产生的新观念变成主流,而它们的术语也会变得像“站立会议”和“结对编程”一样普遍。

查看英文原文: Does Cost Accounting Cause Crappy Code?

2007-06-15 02:001171
用户头像

发布了 100 篇内容, 共 25.7 次阅读, 收获喜欢 5 次。

关注

评论

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

Java开发者快速上手.NET指南

追逐时光者

Java C# .net 微软

使用Terminal.Gui构建功能强大的.NET控制台应用

追逐时光者

C# .net

C#进程调用FFmpeg操作音视频

追逐时光者

C#

.NET异步有多少种实现方式?(异步编程提高系统性能、改善用户体验)

追逐时光者

C# .net

.NET使用原生方法实现文件压缩和解压

追逐时光者

.net

C#字符串拼接的6种方式及其性能分析对比

追逐时光者

C# .net

ML.NET:一个.NET开源、免费、跨平台的机器学习框架

追逐时光者

.net AI

C# 12 新增功能实操!

追逐时光者

C# 微软

在.NET Web API设置响应输出Json数据格式常用的两种方式

追逐时光者

C# .net 微软 WebApi

好消息!数据库管理神器 Navicat 推出免费精简版:Navicat Premium Lite

追逐时光者

数据库 navicat

一款.NET开源跨平台的绘图库 - OxyPlot

追逐时光者

.net

对话式 AI 年度春晚:Convo AI&RTE2025 全议程解锁

声网

从C10K到Reactor:事件驱动,如何重塑高并发服务器的网络架构

poemyang

RPC 事件驱动架构

C#集合数据去重的5种方式及其性能对比测试分析

追逐时光者

C# .net

一款EF Core下高性能、轻量级针对分表分库读写分离的解决方案

追逐时光者

微软 EF Core

基于Bootstrap Blazor开源的.NET通用后台权限管理系统

追逐时光者

C# .net

C#语言编写的仅有8KB大小的简易贪吃蛇开源游戏

追逐时光者

C#

TEN Framework 新增人声分离能力;加州率先对 AI 陪伴聊天机器人实施监管丨日报

声网

EF Core 10 现已支持 LeftJoin 和 RightJoin 运算符查询了!

追逐时光者

C# .net 微软 EF Core

使用dnSpyEx对.NET Core程序集进行反编译、编辑和调试

追逐时光者

.net 微软

在IIS上部署ASP.NET Core Web API和Blazor Wasm

追逐时光者

.net blazor

Windows10 IIS Web服务器安装配置

追逐时光者

微软 IIS

一套基于 Ant Design 和 Blazor 的开源企业级组件库

追逐时光者

C# .net 微软

C#数据结构与算法实战入门指南

追逐时光者

C# .net

GenDev 智能开发:Amazon Q Developer CLI 赋能Amazon Code Family实现代码审核

亚马逊云科技 (Amazon Web Services)

使用 BenchmarkDotNet 对 .NET 代码进行性能基准测试

追逐时光者

C# .net

使用Microsoft.Extensions.AI简化.NET中的AI集成

追逐时光者

.net AI

一款利用人工智能将自然语言查询转换为 SQL 代码的互译工具 - SQL Translator

追逐时光者

数据库

Git从入门到实战详细教程

追逐时光者

git

.NET 9 中 LINQ 新增功能实操

追逐时光者

C# .net

springboot项目集成dolphinscheduler调度器 项目管理

刘大猫

人工智能 云计算 大数据 算法 物联网

成本会计会导致无价值的代码吗?_研发效能_Amr Elssamadisy_InfoQ精选文章