写点什么

敏捷开发人员的责任

  • 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:001345
用户头像

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

关注

评论

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

天池 DeepRec CTR 模型性能优化大赛 - 夺冠技术分享

阿里云大数据AI技术

人工智能 深度学习

如何规避近年频发的数据安全事故?

Zilliz

云原生 云服务 数据安全

备战两个月斩获阿里offer,这份《Java高分面试指南》也太顶了

Java java面试 Java八股文 Java面试题 Java面试八股文

Jasper狂飙:AIGC现象级应用的增长秘笈

OneFlow

人工智能 深度学习 ChatGPT

React Hooks源码深度解析

京东科技开发者

函数 React Hooks 企业号 3 月 PK 榜

GreptimeDB v0.1 发布|原生支持 Python, PromQL 和对象存储

Greptime 格睿科技

云原生 时序数据库 PromQL

还在curd吗?封装属于自己的Spring-Boot-Starter

Java spring Spring Boot Starter

Matlab实现图像分割

timerring

图像分割

共建区块链生态,旺链科技获颁2022年度FISCO BCOS产业应用合作伙伴

旺链科技

区块链 区块链+

ArchKeeper(开篇):架构守护平台的问题与理念

京东科技开发者

架构 敏捷 系统架构 腐化治理 企业号 3 月 PK 榜

IoT物联网平台-规则引擎SQL数据格式详解——设备管理运维类

阿里云AIoT

sql 物联网 数据格式

开源工具系列5:DependencyCheck

HummerCloud

龙蜥白皮书精选:面向 DPU 场景的软硬协同协议栈

OpenAnolis小助手

开源 云原生 内核 SMC协议栈 TCP应用

「金三银四」这些面试题,看看你会答几道?

王中阳Go

Go 后端 面试题 简历优化 就业辅导

贴合运维业务场景的告警聚合实现——以Zabbix为例

观纵科技

zabbix 运维监控 IT运维

2023年深圳.NET线下技术沙龙要开始了!名额有限,报名从速

MASA技术团队

.net MASA

API Gateway vs Load Balancer:选择适合你的网络流量管理组件

API7.ai 技术团队

企业全球化出海技术体系建设实录【专题合集】

阿里技术

技术专题合集 全球化技术能力

如何从5万设备中找出频繁掉线设备,长期不在线的设备?——设备管理运维类

阿里云AIoT

高效学 C++|组合类的构造函数

TiAmo

组合 C++

如何基于 Skywalking 来快速搭建一套应用性能监控平台

观纵科技

APM 全链路监控 Skywalking

IoT物联网时代,如何优化你的网络- DNS域名解析服务——设备接入类

阿里云AIoT

缓存 网络协议 物联网 域名解析 调度

Cloud Kernel SIG月度动态:发布 ANCK 新版本及 Plugsched v1.2.0

OpenAnolis小助手

内核 龙蜥社区 sig anck CVE修复

FTP VS镭速传输,小文件传输技术内有乾坤

镭速

软件测试/测试开发 | Spring Boot 集成 Swagger

测试人

软件测试 springboot 测试发开

详解数仓中sequence的应用场景及优化

华为云开发者联盟

数据库 后端 华为云 华为云开发者联盟 企业号 3 月 PK 榜

JavaScript 对象管家 Proxy

devpoint

JavaScript Proxy ECMAScript 6

还不知道如何在java中终止一个线程?快来,一文给你揭秘

程序那些事

线程 多线程 「Java 25周年」 程序那些事 java

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