2025上半年,最新 AI实践都在这!20+ 应用案例,任听一场议题就值回票价 了解详情
写点什么

敏捷开发人员的责任

  • 2008-01-16
  • 本文字数:1482 字

    阅读完需:约 5 分钟

当客户要求你给出一个快速而肮脏的解决方案时,作为一个开发人员,你的职责是什么?是因为客户是付钱的一方,所以要洗耳恭听,遵照要求走捷径;还是遵守自己的意愿,坚持技术上“最佳”的方案?或者,这二者可以折衷?

James Shore 在《我们的专业职责》一文中简述了客户和开发者之间职责平衡的发展历史:

在过去使用瀑布式开发的那段黑暗岁月中,编程人员得提炼出需求,进行设计,并用技术上最便捷的方式来实现设计方案。开发者就是神一般的存在。计划也完全都是他们制定的。也可能是开发者的大老板来制定最终期限——或许是由政策方面的压力所动,或是根据他曾几何时在某个彪悍周末中的编程成果所留下的传奇式回忆——然后编程人员就为此疲于奔命。** 是的,我是在过分简单化一个复杂的情况。但这没什么不妥。

敏捷开发对此作出了回应:“嘿!等一下!不能这么干!我们并没有给客户带来价值!”于是,计划游戏推动着一切趋于平衡——客户掌控价值,开发人员掌控开销。

但有些敏捷团队把钟摆向另一边推的太远了。他们放弃了自己的职责。他们说:“客户说了算!不管他们说什么我们都要照着做。”

这太离谱了。

他认为,开发者不能充当掌控者的角色,但与之同时也应该担负起开发高质量代码的职责。理应永远如此。

如果有人说,“你能不能走条捷径,干的快点?”你需要凝视着他的眼睛说:“不。”“不,我们不能这样干,否则就会破坏进度。不过我们可以一起找找,看有什么办法把这些特性简化一下,这样就能更快完工了。”

Reg Braithwaite 在《工程学和医学中让我敬佩的专业精神》中说到,有的时候,如果客户想要一个快速而肮脏的解决方案时,听从他们的意见也不算什么坏事:

我不赞同当客户要求你去为了赶时间写一些肮脏而又难以维护的代码时,你可以对他说不。这种想法是好是坏,要靠你自己判断。我的做法是在我与客户或是雇主的关系限定范围内,尽可能的编写整洁的代码。我也在积极推广这种方式。 但是,我并不认为我有权在雇主或是客户坚持立场时,彻底回绝他们的要求。他们会因软件难以维护而遭受损失,所以,是他们,也只有他们在这个话题上有最终的发言权。

他的底线并不是质量,而是道德

在从事软件开发的时候,如果我被要求开发一些不安全、会将私密用户信息置于风险之中的程序,我会做出自己的选择,对这种要求说不。 当然,我并不会受到法律保护。如果我被因此而解雇,我也无处求援。我甚至也没法拿到失业救济,因为我会被认为是因为某些原因被开除的。记住,是你主动选择了这个行业,所以如果你将此作为谋生之本,那么你就必须要以高标准要求自己的道德底线。

Robert Martin(Bob 大叔)在《商业软件是混乱而丑陋的》一文中则陈述说,这种做法是错误的。他的客户里有一名经理说过这样一句话:“商业软件是混乱而丑陋的”,对此他反驳道:

不!绝非如此!商业规则可能很复杂、毫无章法而特殊性又很强;但是代码不一定非要也写成这样子。实际上,商业规则越复杂、越特别、越毫无章法,代码就应该越整洁。当一些乱七八糟的事情左右着整个规则,你怎么可能把无序的规则变的有序!要想从凌乱的规则中抽丝剥茧理清脉络,唯一的途径就是在力所能及的范围内,写出最整洁、最清晰的代码。

最后,在 InfoQ 上曾有一篇新闻写道:重构是必要的浪费(Refactoring is a Necessary Waste),很多读者都围绕着何时进行重构、何时不应重构进行了评论。

那你认为开发人员真正的职责是什么呢?当需要走捷径时,他们应该“仅仅说不”吗?他们应当顺从客户的要求吗?还是应该灵活一些,但又必须关注那些会影响到客户的事情,与之同时坚守自己的价值观和道德?

查看英文原文: An Agile Developer’s Responsibility

2008-01-16 22:001116
用户头像

发布了 197 篇内容, 共 59.3 次阅读, 收获喜欢 21 次。

关注

评论

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

命里有时终须有--记与TiDB的一次次擦肩而过

TiDB 社区干货传送门

人物访谈 社区活动

面试?进大厂?还得靠这份Java面试指导手册

王小凡

Java 面试 JVM Java多线程 秋招

TiCDC同步延迟问题处理

TiDB 社区干货传送门

实践案例 管理与运维 故障排查/诊断 大数据场景实践

TiFlash 源码阅读(五) DeltaTree 存储引擎设计及实现分析 - Part 2

TiDB 社区干货传送门

我和 TiDB 的故事 | 缘份在,那就终是能相遇的

TiDB 社区干货传送门

人物访谈 社区活动

兆骑科创海外高层次人才引进平台,企业项目对接,赛事活动路演

兆骑科创凤阁

Google Cloud X Kyligence|如何从业务视角管理数据湖?

Kyligence

数据湖 智能多维数据库

即时通讯-改变社交与工作状态的新型软件

BeeWorks

我和 TiDB 的故事 | TiDB 对我不离不弃,我亦如此

TiDB 社区干货传送门

人物访谈

基于Flink CDC打通数据实时入湖

数据社

签约计划第三季

数字孪生万物可视 |联接现实世界与数字空间

华为云开发者联盟

云计算 大数据 后端 智慧城市 数字孪生

APP为什么用JSON协议与服务端交互:序列化相关知识

程序员啊叶

Java 编程 程序员 架构 java面试

PD 源码分析- Checker: region 健康卫士

TiDB 社区干货传送门

TiKV 源码解读

【7.22-7.29】写作社区精彩技术博文回顾

InfoQ写作社区官方

优质创作周报

不会多线程还想进BAT?精选19道多线程面试题,有答案边看边学

程序知音

Java 多线程 面试题 后端技术 BAT面试题

容器化 | 在 Rancher 中部署 MySQL 集群

RadonDB

MySQL 开源 容器化 rancher RadonDB

深圳见!云原生加速应用构建专场:来看云原生 FinOps、SRE、高性能计算场景最佳实践

阿里巴巴云原生

阿里云 云原生 峰会

关于数字化转型 你需要知道的八项指导原则

BeeWorks

数据中台建设(四):企业构建数据中台评估

Lansonli

大数据 数据中台 7月月更

突破性能天花板!亚信数据库支撑 10 多亿用户,峰值每秒百万交易

亚信AntDB数据库

AntDB 国产数据库 aisware antdb

手摸手实现Canal如何接入MySQL实现数据写操作监听

知识浅谈

MySQ 7月月更

新四化时代来袭,亚马逊云科技赋能汽车行业加速创新

Lily

StarRocks 2.3 新版本特性介绍

StarRocks

【堡垒机小知识】硬件堡垒机是什么意思?其与云堡垒机有什么区别?

行云管家

云计算 网络安全 数据安全 堡垒机 云堡垒机

兆骑科创赛事活动承办,项目路演,人才引进平台

兆骑科创凤阁

从通信延伸到全行业,亚信科技AntDB 7.0蓄势待发

亚信AntDB数据库

AntDB 国产数据库 aisware antdb

大模型轻量化实践路径

澜舟孟子开源社区

人工智能 自然语言处理 神经网络 深度学习 预训练模型

web前端培训好还是自学前端

小谷哥

TiDB 操作实践 -- 备份与恢复

TiDB 社区干货传送门

备份 & 恢复

TiDB升级与案例分享(TiDB v4.0.1 → v5.4.1)

TiDB 社区干货传送门

实践案例 版本升级 集群管理 管理与运维

TiCDC迁移-TiDB到MySQL测试

TiDB 社区干货传送门

管理与运维

敏捷开发人员的责任_研发效能_Amr Elssamadisy_InfoQ精选文章