写点什么

QCon SF 闭幕主题演讲:软件设计是一种人际关系活动

作者:Shane Hastie

  • 2022-12-16
    北京
  • 本文字数:1789 字

    阅读完需:约 6 分钟

QCon SF闭幕主题演讲:软件设计是一种人际关系活动

AI 大模型超全落地场景&金融应用实践,8 月 16 - 19 日 FCon x AICon 大会联诀来袭、干货翻倍!

Kent Beck敏捷软件开发宣言的最初签署人之一(按字母顺序排在第一位的签署人),他在本周的QCon旧金山大会上发表了闭幕主题演讲。他演讲的题目是“整洁第一?(Tidy First)”,这也是他即将出版的新书的名字。

 

首先,他介绍了自己的个人使命:帮助极客们在这个世界上获得安全感。关于这一点,他在一篇发表在Facebook的博文中解释过。

 

他谈到,最近重读了 Ed Yourdon 和 Larry Constantine 的著作《结构化设计》。按照他的说法,这本书里包含软件开发的牛顿定律;对于如今的编程来说,其中的概念和思想还和这本书刚出版时一样重要。书中介绍的耦合和内聚两个概念,即使在今天,也仍然是软件工程的一大挑战,就像这本书在 1975 年出版时一样。

 

他说,他花了 17 年的时间才学会如何解释软件设计中的内聚概念,以此为契机,他写了一系列三本书来探索软件设计。感兴趣的读者,可以在Substack上阅读。

 

他说:

软件设计是一种人际关系活动。


正是通过探索这些关系,软件系统才出现在了这个世界上。

 

第一个关系是希望探索的想法和将想法变成现实的行为之间的关系。这种关系是双向的,是不断发展的——想法定义了行为,行为的存在可以催生更多的想法(“现在我看到了这个,那么那个呢……”)。在思想和行为的背后是系统结构,也就是架构,它对可见行为有着深远的影响。

 

系统结构对行为有着深远的影响,对因行为改变而产生的想法也有深远的影响。结构影响行为,从而产生新的想法,催生行为更改需求,进而影响结构,不断循环。在“整洁第一”工作流中,我们得以暂停一下,问问自己是否需要更改结构,或者只需更改行为。如果更改影响了结构,那么要首先整理下结构——根据需要重构底层架构。不要试图同时更改结构和行为,因为那会导致系统陷入技术债务。

 

他说,在构建系统时,特别是在必须更改系统时,涉及两种视角,分别是等待者(waiters)和变更者(changers)。等待者有了想法,就会希望尽快更改行为,尝试新事物;变更者则必须维护代码,并整理结构,为的是可以安全地更改行为。

 

当有多个变更者负责同一产品的不同领域时,复杂性会进一步增加。等待者的动机和不同变更者的竞争性动机之间很可能出现关系紧张的情况。

 

软件设计技能就在于保持不同生产者以及变更者和等待者之间的良好关系。

 

通常,变更者在收到更改产品的请求时会面临这样的问题:“这段代码很乱——我应该先整理再更改吗?”这个问题的答案通常很教条:当然应该或者当然不应该——我们希望尽快更改,并且希望可以保证代码库不受技术债务的影响。遗憾的是,两者无法兼得。我们需要做出决策,而正确的答案只能是“视情况而定”。

 

为了说明等待者-变更者生态系统中的不同关系,他画了下面这幅图:



然后,他解释了为什么大量的前期设计在 20 世纪 90 年代是一个馊主意,而且直到今天仍然是一个馊主意。他说,瀑布式开发又回来了,有些组织再次尝试根据预先定义好的时间、成本和范围来定义软件开发的成功与否。他还解释了为什么增量迭代开发始终是构建软件系统最经济可靠的方法,而且如今更是如此。

 

他讨论了Constantine的对等概念:软件系统的实际成本是更改系统的成本。在系统的生命周期中,维护系统的成本将使初始开发成本在整体投资中的占比变得很小。然后,他展示了维护产品的成本如何与系统耦合的成本直接相关。对系统中一个元素的更改导致了对另一个元素的级联更改,进而又导致了对另一个元素的更改,诸如此类……

 

系统的总体成本可以看作是系统元素的耦合成本与解耦成本之和(他用了元素这个词,代码的实际性质和我们这里介绍的内容没有关系——那可以是函数、远程过程、微服务或任何其他相关的组件)。

 

系统的底层结构(架构、设计)是耦合/解耦问题中最重要的一个因素。

 

当考虑更改系统时,可能大多数情况下都是在没有多少级联耦合的部分进行,然而,在产品的生命周期中,可能有一些巨大的更改——其中耦合级联如此之大,以致更改成本变成了天文数字。在系统的使用周期中,这些巨大的更改很可能占了维护成本的绝大部分。



最后,他鼓励听众进行小幅增量更改,尽可能保持系统结构的整洁与解耦,并采取“整洁优先”的方法进行软件维护。

 

原文链接:

https://www.infoq.com/news/2022/10/beck-design-human-relationships/


相关阅读:

只擅长构建软件是不够的,我们必须擅长构建可测试的软件 | QCon

为下一个 Log4Shell 漏洞做好准备 | QCon

如何使用区块链构建 Web 3.0 基础设施|QCon

2022-12-16 08:004178

评论

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

C#入门系列(二十) -- 面向对象之封装

陈言必行

C# 6月月更

618战报销冠谜底:“收割机”联想屠榜背后的三大利器是什么?

脑极体

ImportSelector与DeferredImportSelector的区别(spring4)

程序员欣宸

Java spring SpringFramework 6月月更

面试突击58:truncate、delete和drop的6大区别

王磊

Java java常见面试题 常见面试题

redis内存优化

乌龟哥哥

6月月更

解决k8s调度不均衡问题

劼哥stone

Kubernetes 云原生 调度 调度不均衡 kube-scheduler

敲了几万行源码后,我给Mybatis画了张“全地图”

小傅哥

源码分析 面试 小傅哥 mybatis 大厂面试

初创公司,如何拥有企业级Java脚手架

昵称不能为null

Java脚手架 企业级代码架构

【LeetCode】出现次数最多的子树元素和Java题解

Albert

LeetCode 6月月更

案例驱动 :从入门到掌握Shell编程详细指南

百思不得小赵

bash 运维 6月月更

本周二晚19:00战码先锋第6期直播丨共建测试子系统,赋能开发者提高代码质量

OpenHarmony开发者

OpenHarmony

基于集群的动态反馈负载均衡策略

No Silver Bullet

集群 6月月更 负载均衡策略

开源生态|超实用开源License基础知识扫盲帖(下)

Orillusion

开源 WebGL 元宇宙 Metaverse webgpu

dart使用技巧集合【01】

坚果

6月月更

DOM

Jason199

DOM js 6月月更

《网络是怎么样连接的》读书笔记 - Tcp/IP连接(二)

懒时小窝

TCP 网络编程 IP

Linux开发_采用线程处理网络请求

DS小龙哥

6月月更

DOM核心——Element类型

大熊G

JavaScript 前端 6月月更

vivo 容器集群监控系统架构与实践

vivo互联网技术

云原生 监控 系统架构 Prometheus

IAST 初探:博采众长、精准定位、DevOps友好

SEAL安全

DevOps 安全 IAST 应用安全测试 开源软件供应链

uni-app进阶之生命周期【day8】

恒山其若陋兮

6月月更

Python 设计模式:原型模式

宇宙之一粟

设计模式 原型模式 6月月更

【愚公系列】2022年06月 通用职责分配原则(八)-中介原则

愚公搬代码

6月月更

读书笔记之:麦肯锡高效工作法

甜甜的白桃

读书笔记 读书 笔记 6月月更

Java技术培训之设计模式七大原则

@零度

设计模式 JAVA开发

远程办公三部曲 - 如何提高工作效率| 社区征文

耳东@Erdong

工作效率 远程办公 6月月更 初夏征文

scanf的使用,cin和scanf的区别

工程师日月

6月月更

【作业四 千万级学生管理系统的考试试卷存储方案】

wuli洋

【Spring 学习笔记(十四)】Spring AOP 通知中获取数据

倔强的牛角

Java spring 6月月更

Jenkins 通过检查代码提交自动触发编译

HoneyMoose

【Python技能树共建】字符编码与解码

梦想橡皮擦

Python 6月月更

QCon SF闭幕主题演讲:软件设计是一种人际关系活动_文化 & 方法_InfoQ精选文章