NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

停止过度设计,开发客户需要的软件

  • 2016-06-30
  • 本文字数:1354 字

    阅读完需:约 4 分钟

在与许多不同的团队合作过之后, Greg Young 发现大家做项目时经常会大幅度的过度设计。比如一个预计要开发 9 个月的项目,换个角度思考一下,却可能只需要几个星期就可以提交 95% 的功能。Young 在最近伦敦举行的 DDD eXchange 大会着重阐述了这一点。

过度设计的原因就是我们在开发错误的东西。在Young 看来,我们并没有对客户到底需要什么给以予足够的关注,我们关注的是我们认为客户需要什么,而实际上这是两件非常不同的事。大多数情况下,项目功能的使用情况会遵从帕雷托分布(80/20 法则),即只要实现一小部分功能,就可以满足绝大部分场景下的实际使用需要。如果继续开发剩余的使用率极低的功能的话,会需要投入非常多的精力,而只能获得非常少的收益。

Young 强调软件只是一个大系统的一小部分。除了软件我们还有一整套的业务流程,而某些细节问题是完全可以用业务流程去解决的,不一定全要通过软件解决。平时我们过多的讨论了最极端的情况下如何用软件解决问题。其实我们完全可以把工作内容的 99.9% 用软件自动化处理掉,然后把剩余的一小部分留给熟悉业务的人去手工解决。

人工介入是有必要的,人类来了!

棕地项目”是有可能被过度设计的一类。对于 Young 来说,这些项目也是最容易避免过度设计的,因为人们对这样的系统已经有了使用经验和数据。根据熟悉业务的人的描述找到系统的基本用例,再对照实际的使用情况,就基本可以确认绝大部分的系统功能了。不幸的是,我们和熟悉业务的人讨论得最多的却常常是系统的边缘功能,就是那些在编码时需要大量复杂处理可实际上却很少在生产环境中能用到的功能。Young 也指出,考虑这些复杂处理事实上会误导我们的项目模型设计。

绿地项目”则是经常被过度设计的一类,因为我们没法接触到实际的使用情况。为了避免过度设计,Young 建议与需求方达成协议可以在项目首次提交的两个月后再次部署和发布。期间,需求方要使用这个系统并尽早的提供反馈,这样来避免实现那些几乎用不上的功能。他也建议在第一次发布之后只解决故障而不开发新功能,这样所有缺失的功能就都会被当成故障报告上来。根据他的经验这样工作非常有成效,因为大家只需要分析故障的严重程度来决定处理的优先级就可以了。但他也提到,这种工作方式只适用于给内部用户使用的内部项目,对固定价格的合同或者公用的网站不适合。

我们就是在梦想国里开发绿地项目的。

项目经理或项目协调者是非常容易做过度设计的人。Young 几乎没见过什么项目是可以兼顾多种用途而获得成功的,最大的原因是要满足各方面的细节需求就会导致最终做成一个庞大的项目。更过份的是有的项目甚至会迷失,想不明白自己最主要是想实现什么功能了,结果大家就只好把各种可能情况都列举出来,事情就完全不可控了。

Young 总结到:我们应该记住现在软件系统已经在取代人工工作了。大多数的情况下能让软件系统完成 99% 的人工工作就已经非常好了,想再把剩下的 1% 也搞定,这事算起账来并不划算。

明年的DDD Exchange 大会计划在2017 年四月下旬如开,现在正在开放注册。

查看英文原文 Stop Over-Engineering, Build What the Customer Really Needs


感谢夏雪对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ @丁晓昀),微信(微信号: InfoQChina )关注我们。

2016-06-30 18:003034
用户头像

发布了 152 篇内容, 共 68.0 次阅读, 收获喜欢 63 次。

关注

评论

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

欢迎新大陆软件加入openGauss社区

openGauss

cuda+cudnn ubuntu20安装

Ayosh

Python进阶(五)浅谈python匿名函数及编写无参数decorator

No Silver Bullet

Python 10月月更 匿名函数 无参数decorator

LinkedList源码分析(二)

知识浅谈

linkedlist 10月月更

Python进阶(七)浅谈python3和Python2的区别

No Silver Bullet

Python3 区别 10月月更 Python2

Qt | 实现自定义手机号输入框控件

YOLO.

qt 10月月更 C++

【LeetCode】优势洗牌Java题解

Albert

LeetCode 10月月更

云和恩墨大讲堂 x openGauss Meetup x 鲲鹏生态孵化营(上海站)圆满落幕

openGauss

首份把架构三原则拆开来讲的“架构师宝典”,电子版已上线

Geek_0c76c3

Java 数据库 开源 程序员 开发

【算法作业】实验四:逆波兰表达式求值 & Fibonacci数列的尾递归与非递归程序

清风莫追

数据结构 算法 10月月更

10项任务助你落地架构课程!

华仔

架构实战营

C++ | 关于extern关键字的使用

YOLO.

qt 10月月更 C++

欢迎奥看科技加入openGauss社区

openGauss

Java 隐藏 Word 文档中的特定段落

在下毛毛雨

欢迎海天起点加入openGauss社区

openGauss

大数据ELK(十八):Beats 简单介绍和FileBeat工作原理

Lansonli

10月月更 大数据ELK

MFC|CCombobox控件修改编辑框光标显示位置

中国好公民st

c c++ 10月月更

如何实时、高效地处理如此海量的路况数据

华为云开发者联盟

人工智能 华为云 图片处理 智慧交通 企业号十月 PK 榜

DDD 建模案例分享

Bright

敏捷 DDD TDD

Java的跨平台和环境搭建

共饮一杯无

jdk java基础 10月月更 java环境搭建

Node.js TLSSocket 库里涉及到的证书链的概念简介

Jerry Wang

JavaScript node.js 后端开发 SAP 10月月更

hashmap常见面试题

普罗米修斯

10月月更

不要小看一个Redis!阿里最新开源Redis核心原理+应用实践,涵盖了Redis的所有操作

程序员小毕

面试 程序人生 中间件 Java后端 redis 底层原理

【算法作业】实验二:给立方体排序的小明&&同时整除的数

清风莫追

数据结构 算法 10月月更

Photoshop软件应用项目(二)

张立梵

设计师 ps 10月月更

从零开始学Graph Database:什么是图

华为云开发者联盟

人工智能 华为云 图数据库 图计算引擎 企业号十月 PK 榜

【算法作业】实验三:划分集合-贪心 & 可能的IP地址-回溯

清风莫追

数据结构 算法 10月月更

Github 访问量过百万!阿里内部springcloud手册, 实至名归

Geek_0c76c3

Java 数据库 程序员 开发

【Java深入学习】join再理解

Geek_65222d

10月月更

【Java深入学习】可见性

Geek_65222d

10月月更

IDEA的Docker插件实战(Dockerfile篇)

程序员欣宸

Docker IDEA 10月月更

停止过度设计,开发客户需要的软件_研发效能_Jan Stenberg_InfoQ精选文章