在 2025 收官前,看清 Data + AI 的真实走向,点击查看 BUILD 大会精华版 了解详情
写点什么

“实效主义”是一匹“黑马” —— 现实驱动开发

  • 2008-03-04
  • 本文字数:1095 字

    阅读完需:约 4 分钟

软件架构师 Gustavo Duarte 的一些观点最近引起了热烈的讨论。针对物理学家 Richard Feynman 关于挑战者号航天飞机失事报告以及其中的一些发现,他提出了一些观点,并讨论了它们与工程级质量软件的关系。Gustavo 将 Feynma 的原则应用于软件领域,并提出四个主要观点:

  • 软件工程的好坏和它与管理的关系是正相关的;
  • 大量的事先设计非常“愚蠢”;
  • 软件与其他工程上的法则有很多共同之处;
  • 可靠的系统是通过严格的测试、以“确保最高质量的态度”采取自底向上增量式工程化开发得到的。

在后续的一篇文章中,Gustavo 详细阐述了“实证”的概念, 并引入了“现实驱动开发(Reality Driven Development)”这一想法:

行动和尝试是经验主义的基石。不要试图让现实屈从于广泛的分析和丰富的文档,因为现实是通过试验得来的。某个以经验主义为指导方针的公司不会苦苦执着于市场研究,而是雇佣实习生用一个夏天的时间开发出一个产品。而不以经验主义为依据的公司会组织 43 个人用了一年的时间进行计划和设计却没有付之实施

从进化角度来看,这一概念奉行“适者生存”的哲学。实质上,你尝试一些东西,然后取其精华去其糟粕。Gustavo 解释到:

好的软件开发过程应该完善那些尝试,从现实结果中得到反馈。这就是我想通过“现实驱动的开发”所表达的意思。而对于软件来说,最重要的现实就是用户体验和技术质量(technical quality),而主要的试验就是写代码和软件。这并不是一个非常正式的模型(呵呵),我只是喜欢用它来代表软件开发。我喜欢“现实驱动”这个词,因为当你提到“现实”时,人们会想到“用户”。

该想法与敏捷共享一些共同的核心原则和技术,而 Gustavo 并没有提倡某种新方法论(感谢上帝):

现实驱动开发没有什么特定的方法论,它与敏捷原则有很多共通的想法(当然敏捷原则会影响这些想法),但魔鬼存在于细节之中。我喜欢将软件工程想象为工具箱,其中充满了我们根据正确的形势要选择的技术。“完善那些尝试”的过程工具包括迭代开发可执行的架构(executable architecture), 持续集成,以及单元测试

Gustavo 的方法更偏爱用户和质量:

基于这一模型,我们在意的就是以下两个现实:用户体验(包括软件实用性)和技术质量。而在敏捷和类似瀑布这样的方法中,用户体验常常被忽视[译者注:敏捷方法是强调用户体验的]。

Gustavo 用自低向上的方法总结到:

  1. 更注重试验而不是分析,尽管二者都很重要;
  2. 完善试验:尽可能让这些试验更容易、更快、更便宜、更广泛。分析可以帮助我们这一点;
  3. 更多的尝试;
  4. 必须聪明和主动地度量现实:即用户体验和技术质量;
  5. 对反馈做出反应,让现实来驱动。

查看英文原文: Pragmatic is the new black - Reality Driven Development

2008-03-04 20:391307
用户头像

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

关注

评论

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

Hive MetaStore的实现和优化

数新网络官方账号

澳鹏代码类数据集:下一代AI编程的"高能燃料"

澳鹏Appen

代码 数据集 代码库 代码数据集

Alpha公司主体库:一键穿透企业集团复杂结构,开启尽职调查新纪元

科技汇

解析RFID盘点通道机在库存管理中的重要性

斯科信息

如何提升YashanDB数据库的安全性?

数据库砖家

评估YashanDB数据库的性能监测工具

数据库砖家

如何在YashanDB数据库中保持数据一致性与完整性

数据库砖家

2025年推荐6个好用的 Postman 替代工具

不在线第一只蜗牛

开源 Postman

如何有效管理YashanDB的访问控制

数据库砖家

如何评估YashanDB在企业数字化转型中的价值

数据库砖家

如何在YashanDB数据库中高效处理海量数据

数据库砖家

如何在YashanDB数据库中管理用户权限

数据库砖家

ODPS 15周年开发者活动|征文+动手实践双赛道开启,参与活动赢定制好礼!

阿里云大数据AI技术

人工智能 云计算 大数据 阿里云 ODPS

如何评估YashanDB的性能与稳定性?

数据库砖家

如何设计基于YashanDB数据库的高效查询

数据库砖家

如何实现YashanDB数据库中的数据加密

数据库砖家

提升YashanDB数据库的数据处理效率

数据库砖家

如何维护YashanDB的数据库性能监控

数据库砖家

如何应对YashanDB数据库中的数据一致性挑战

数据库砖家

如何在YashanDB数据库中定义和管理权限

数据库砖家

JNPF——低代码领域全能助手

秃头小帅oi

如何评估YashanDB的企业适用性?实用指南

数据库砖家

如何实现YashanDB数据库的容器化部署与管理

数据库砖家

如何实现YashanDB中的数据冗余处理

数据库砖家

如何用YashanDB进行数据审计与合规性管理

数据库砖家

QAT 查表算子调优 02 | 查表算子精度调优

地平线开发者

自动驾驶 算法工具链 地平线征程6

如何实现YashanDB数据库的负载均衡

数据库砖家

如何确保YashanDB数据库的性能稳定?

数据库砖家

VKProxy新增一些功能

八苦-瞿昙

Proxy

如何评估YashanDB的查询性能

数据库砖家

“实效主义”是一匹“黑马” —— 现实驱动开发_研发效能_Gavin Terrill_InfoQ精选文章