软件研发的道德情操

news2025/2/14 3:32:36

作者:许晓斌(晓斌)

两百多年前苏格兰出了一位大哲学家,他的名字叫做亚当·斯密。今天人们对他的了解更多是在经济学家这个身份,都认为是他发现了“看不见的手”这一神奇的经济规律,以及他那本著名的《国富论》。然而除了这本书之外,斯密还出版了另外一本巨著——《道德情操论》(The Theory of Moral Sentiments),这是一部难得的哲学以及文学佳作。值得一提的是,我认为此书可以帮助我们去理解当代软件工程遇到的各种问题,也可以帮助我们探索一些解决之类难题的方法。

图片

一、同理心

现代社会流行 ”同理心“(或称”共情“) 这个词,这个词用英文来表达是 _empathy_,例如我们在街上看到一对久别重聚的恋人,他们快乐的笑容,能够让我们会心一笑;而当我们看到有人因为罹患重病而一筹莫展的时候,我们也会发自内心地感到伤感。



当然,我们共情他人的快乐、悲伤、愤怒,除了因为这个人表现出来的情绪之外,还因为理解他表现情绪的动机,并且其动机是合理的。例如,如果某人因为被不小心撞了下,就愤怒地拿出刀来要去刺那个撞他的人,那么我们就绝不会共情这种愤怒;但是如果某人的妻女被人强奸,而他愤怒地拿出刀来要去刺那个伤害他家人的罪犯,我们都是能理解并认可这种愤怒的。



虽然人都有共情的能力,但能体验到的他人的快乐和悲伤的程度,相比自己的切身体验,往往是很弱的。一个病危的人的无助和孤独,陌生人即便在当场观察良久,能体验的到无助,恐怕还不到十一;一个中彩票的人的狂喜,旁人所能有的快乐体验也是很弱的,有的甚至还可能会有妒忌的情绪。



作为情绪的感受者和表现者,当我们的快乐、悲伤、愤怒等情绪,被周围的人所认可,那么我们的快乐会加倍,我们的悲伤亦能的到缓解,我们的愤怒亦能被认可是正当的,进而得到发泄。



在斯密看来,社会的奖惩机制,就是基于社会中人与人的共情原理发展而来的。当一个人,出于良好的动机,做出一些行为,并让他人收获舒服和快乐,那么旁观者就能共情到受惠人的舒服和快乐情绪,也能理解施惠人的良好动机,那么就会同意奖励施惠人;当一个人,出于不良的动机,做出一些行为,并让他人收获痛苦和悲伤,那么旁观者就能共情到受害者的痛苦,也不会赞同施害人的不良动机,那么就会同意对施害人进行惩罚。



奖励的例子有,小河边路过的青年看到水里有落水的儿童,他出于救人的动机,实行了救助行为,最终儿童得救,儿童一家逃脱厄运,作为旁观者的我们,都会赞同对这个青年给予奖励;就惩罚而言,所有犯罪案例都是例子,例如路边有人看到商店里的手机,为了满足自己的私欲,实行窃取行为,对商店的主人造成了损害,那么作为旁观者的我们,会同意对盗窃者施行惩罚。

二、道德观与软件研发

基于同理心,人与人之间渐渐形成了奖励和惩罚的共识。斯密认为所谓道德,就是这么一些共识(或者说规则),当社会遵循这些共识的时候,整个社会就欣欣向荣。而那些无法形成良好共识,或者说共识得不到社会遵循的时候,那社会的发展就会出问题,渐渐走向衰落。斯密写作比达尔文早了一个世纪,但是这里我们能看到进化论的影子,即,对于自然(或曰上帝)来说,能进化出道德的社会才能让这个社会更好的适应自然,进而繁荣。



社会中,人与人相处,不能只考虑自己的情感而无视他人的悲欢。人在考虑自己感受的同时,也必须学会考虑他人的感受,并做出有益他人的行为,如此整个社会才能繁荣。



让我们回到在软件研发这件事情中。类似的,开发者不能只考虑自己,也不能只考虑机器,他必须要学会考虑其他开发者的感受,做出有益于其他开发者的行为,如此整个研发组织才能繁荣。许多开发者会错误地认为,软件只要能运行起来就没事了,和机器有关,和其他人无关;但每个人只要想想自己在过去一年中阅读了多少其他人写的代码,维护了多少其他人交接的系统,就会明白这种想法是多么的错误了。没有开发者是从零开始编写软件的,在大型组织中,开发者每天都依赖其他开发者的中间产物进行工作,而自己也在不断生产中间产物,这些中间产物包括:



  • 文档:描述系统是如何设计,描述 API 是如何使用的。当研发工作依赖一个现有系统的时候,就必须要理解现有系统的设计,尤其是当需要对这个系统做改造的时候,就必须明白设计的核心模型。

  • 代码:无论是使用他人提供的 service(及 client),还是使用中间件框架,还是接手遗留系统。进行新的研发工作都需要去深入理解这些代码,这些代码是否容易理解,是否引入不必要的依赖,是否有足够的测试覆盖(因此容易修改),都会很大程度上影响研发的效率。

  • 服务:上层的业务会依赖大量的下层服务,尤其是在测试阶段,下层服务的质量和稳定性会对测试工作的效率造成极大的影响。比较底层的一些服务,如缓存,消息等,现在通常都是云提供的,而这些服务的质量往往都比较高。



当我们在日常研发工作中,使用到的软件中间产物,在其质量非常高的时候,我们会由衷地对于这些中间产物的作者生出感激、敬佩的情感;而在其质量非常差的时候,我们则会从内心泛起对中间产物作者的厌恶、鄙视之情。



而当组织中的每个人,作为中间产物的作者,能在生产和交付文档、代码和服务的时候,时刻考虑到这些文档、代码和服务的质量,会对其他的开发者产生重大的影响,进而约束自己的行为,用更高的质量标准要求自己,以期待从中间产物的使用者那里收获赞许和感激,而非厌恶和鄙视,那么这个组织就形成了良好的软件研发道德观。

三、Postel's Law

计算机领域中有一条可能不那么知名的设计原则:Postel’s Law(也被称为 Robustness principle):

> Be conservative in what you do, be liberal in what you accept from others.

这条原则最早是 Jon Postel 在 TCP 协议中描述的,当计算机之间通过协议通讯的时候, 对于其他计算机发送给自己的内容,要考虑各种异常、不规范的情况,即要主动消化各种复杂度;而当自己给其他计算机发送内容的时候,则要有严谨的 Spec,并且严苛地遵守 Spec。

图片

虽然 Postel's Law 讨论的范畴是系统设计,但我认为要形成高效的研发团队,人与人之间的协作也应该遵循同样的原则,作为软件中间产物的作者,每个研发都应该对自己的产物提供清晰的 Spec 并严格遵循这些 Spec。只有 “be conservative in what you do”,那么一层层往上的研发工作,其效率才能够得以保持(甚至提高),否则的话,最上层的研发工作就犹如在一个摇摇晃晃的梯子上装灯泡,其效率之低可想而知。

四、软件研发道德的失效

前文我尝试说明:软件中间产物的质量(包括文档、代码和服务)对于研发组织的整体效率是至关重要的;良好的软件研发道德,或者有时候也会认为这是良好的工程师文化,就是大家形成一种以交付高质量软件中间产物为荣,以交付低质量软件中间产物为耻的共识文化。



然而在实际的情况下,我们往往看到很多组织未能形成这种共识文化。相反的,系统无清晰的设计文档,为了快速上线代码不做 code review,系统不做充分测试,代码没有单元测试覆盖,为他人提供的 client 加入了大量无关的依赖,种种现象司空见惯,简直可以用罄竹难书来形容。



当研发遇到这种软件研发道德失效的情况,往往会觉得沮丧、无力甚至愤怒。一些人因此觉得研发环境恶劣、团队缺乏吸引力、领导无能;另一些人觉得工作就是如此,尽管不理想但也默默接受并习惯。试图改变不理想的现状,但是失败以至于离开;或者对现状感到麻木并习以为常,似乎是再常见不过的结果。



如果我们再思考一下斯密关于道德形成的理论,就能够理解为何组织中软件研发道德会失效,这种失效的直接原因是:

1. 生产高质量软件中间产物的行为没有得到应有的奖励。

2. 生产低质量软件中间产物的行为没有得到应有的惩罚。



当我们和任何一个研发的 TL 讨论软件质量的时候,没有一个 TL 会和你说软件质量不重要。但是我们都明白,一件事情的关键不在于那个人怎么说,而在于那个人怎么做。而怎么做具体就体现在:当质量和其他因素的优先级发生冲突的时候,这个 TL 会如何做出选择;当 TL 给团队做绩效评定和晋升的时候,是否研发质量作为一项核心的考核指标。



而在软件研发道德的失效的组织和团队,我们无一例外地看到:当质量和时间发生冲突的时候,优先级被放在了时间上,质量被牺牲了;当质量和功能范围发生冲突的时候,优先级被放在了功能范围扩大上,质量被牺牲;在做绩效评定的时候,并没有认真考核研发在质量上做的贡献,换言之,对一个研发同学的短期业务结果,规划思考能力,质量贡献等角度综合评定的时候,质量贡献往往被忽略了。



我以前一直认为软件质量的问题,研发效率的问题,是技术的问题,是因为先进的技术没有得到理解和应用;但是行文至此,相信大家能理解,我的观点已经发生了改变,软件质量和研发效率的核心不是技术问题,而是一种类似社会学的问题,是人的问题。

五、应该怎么做?

既然是人的问题,就必须从改变人的行为入手,这里首先要让质量的信息透明化,其实是要让质量相关的行为得到应有的评价。透明化是合理评价的前提。

无论是敏捷软件开发的方法论,还是精益的方法论,都强调 Build Quanlity In,这句话的意思是,质量是在每一个过程细节中建设起来的,只看最终的软件产品的质量,或者结果质量,是不行的。一旦过程质量被忽略,大量的返工,大量的问题修复,会严重影响产品交付的速度。



今天大部分组织都非常关注结果质量,最典型的就是服务的可用性,客诉等等。这本身没有问题,但令人失望的是,似乎很少组织保持了对 Build Quanlity In,对过程质量的足够关注,这些信息没有得到清晰透明地展现。因此要将过程质量透明化,在软件研发过程中,具体包括:



  1. 代码全面开放:让每个研发提交的代码都能被其他人看到(git blame 是个很好用的命令),代码质量的好坏自然一目了然;

  2. 开发文档全面开放(也需要有版本化记录):让每个研发的设计和思考都能被其他人看到;

  3. Code Review 机制的推行,让代码进入主干之前都能被同事认真审视;

  4. CI Dashboard:是否有足够的自动化单元测试覆盖等等,也得到透明的展示。



质量信息透明只是第一步,第二步是信息的透明和激励机制挂钩。这就好比,假设我们白天在马路上都能看到有车闯红灯,但实际上闯红灯不会被扣分罚款,那总还是有很多人会继续闯红灯的的;再好比我们看到有人在马路上扶起倒地老人,我们都知道他做了正确的事情,可是当老人不感谢他反而讹诈他,而且没人出面帮助他证明的时候,此人再高尚也不会继续施行善举。



因此组织在绩效评定的时候一定要把研发人员的软件质量贡献纳入核心的考核标准。但这个时候问题又来了,主管是否有能力评价团队每个研发的研发质量?或者说,主管是否关心每个研发的研发质量?



我想表达的第一个观点是:主管的核心职责之一应该是关心研发质量,因为这决定了组织的研发效率,不关心这一点的主管,是不称职的。



我想表达的第二个观点是:主管不一定有能力全面评价团队每个研发的研发质量,因为有些团队规模较大之后,主管对于细节的把握就有心无力了,但是这个时候他可以做两件事情:

  1. 透明、透明、透明:让团队,以及跨团队的质量信息让所有人都能看到。

  2. 引入环评机制:让团队中或者跨团队中,那些技术资深,质量过硬的研发同学一起参与评价。



持续激励组织需要的行为,反对甚至惩罚对组织有害的行为,是管理者的核心职责之一。作为软件研发团队的管理者,必须要能够深刻理解对于软件研发有益和有害的行为,然后在团队建立长效的机制。最终建立一个研发充满幸福感,能够充分释放自己创造力的环境。这样的组织,在商业上也必然是充满竞争力的。



以上,是亚当斯密对我的启发,我称之为“软件研发的道德情操”。

延伸阅读

[01] 亚当·斯密的《道德情操论》

https://en.wikipedia.org/wiki/Relational_algebra

[02] Postel's law

https://devopedia.org/postel-s-law

[03] Build Quality In

https://www.scaledagileframework.com/built-in-quality/

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/863815.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

一文详解自然语言处理两大任务与代码实战:NLU与NLG

目录 1. 自然语言处理定义NLP的定义和重要性NLP的主要挑战 2. 基础模型语言模型统计语言模型n-gram模型 连续词袋模型 3. 基础概念词向量Word2VecSkip-Gram GloVeFastText1. 子词表示2. 词向量训练3. 文本分类4. 预训练模型 4. 文本预处理分词去除停用词词干提取和词形还原文本…

R语言的物种气候生态位动态量化与分布特征模拟实践技术

在全球气候快速变化的背景下,理解并预测生物种群如何应对气候变化,特别是它们的地理分布如何变化,已经变得至关重要。利用R语言进行物种气候生态位动态量化与分布特征模拟,不仅可以量化描述物种对环境的需求和适应性,预…

2021年09月 C/C++(一级)真题解析#中国电子学会#全国青少年软件编程等级考试

第1题:数字判断 输入一个字符,如何输入的字符是数字,输出yes,否则输出no 输入 一个字符 输出 如何输入的字符是数字,输出yes,否则输出no 样例1输入 样例1输入 5 样例1输出 yes 样例2输入 A 样例2输出 no 下…

工程优化问题之三杆桁架设计研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

【UniApp开发小程序】小程序首页(展示商品、商品搜索、商品分类搜索)【后端基于若依管理系统开发】

文章目录 界面效果界面实现工具js页面首页让文字只显示两行路由跳转传递对象将商品分为两列显示使用中划线划掉原价 后端商品controllerservicemappersql 界面效果 【说明】 界面中商品的图片来源于闲鱼,若侵权请联系删除关于商品分类页面的实现,请在我…

JVM——Java 内存区域详解

文章目录 写在前面 (常见面试题)基本问题拓展问题 一 概述二 运行时数据区域2.1 程序计数器2.2 Java 虚拟机栈2.3 本地方法栈2.4 堆2.5 方法区2.5.1 方法区和永久代的关系2.5.2 常用参数2.5.3 为什么要将永久代 (PermGen) 替换为元空间 (MetaSpace) 呢? 2.6 运行时常量池2.7 直…

DP(背包模型)

求方案数初始化总结 二维 1.体积至多是 j f[0][i]1 (0<i<m) 其余为 0 &#xff08;因为体积是至多是j 它可以小于j f[0][0]1 是肯定的 f[0][i] 这当中 i也可以包括0 一定要get到至多 即便不选物品 f[0][i]也是 1 它可以包含f[0][0]) 2.体积恰好是 j f[0][0]1 其余都…

MATLAB | 绘图复刻(十一) | 截断的含散点及误差棒的分组柱状图

hey大家好久不见&#xff0c;本期带来一篇绘图复刻&#xff0c;居然已经出到第11篇了&#xff0c;不知道有朝一日有没有机会破百&#xff0c;本期绘制的是《PNAS》期刊中pnas.2200057120文章的figure03&#xff0c;文章题目为Intranasal delivery of full-length anti-Nogo-A a…

SaaS BI数据可视化工具:免下载安装,登录即分析

之前有人问我&#xff0c;说&#xff1a;“BI数据可视化工具总是要下载安装&#xff0c;过程繁琐&#xff0c;没点IT基础的人也不太搞得定&#xff0c;有没有不用下载安装就能用的数据可视化工具&#xff1f;”答案当然是有的&#xff0c;那就是SaaS BI数据可视化工具。 SaaS …

并发——AQS原理以及AQS同步组件总结

文章目录 1 AQS 简单介绍2 AQS 原理2.1 AQS 原理概览2.2 AQS 对资源的共享方式2.3 AQS 底层使用了模板方法模式 3 Semaphore(信号量)-允许多个线程同时访问4 CountDownLatch &#xff08;倒计时器&#xff09;4.1 CountDownLatch 的两种典型用法4.2 CountDownLatch 的使用示例4…

生信豆芽菜-箱线图使用说明

网站&#xff1a;http://www.sxdyc.com/visualsBoxplot 一、使用方法 1.打开网址&#xff08;http://www.sxdyc.com/singleCollectionTool?href-diff&#xff09;&#xff0c;选择“箱线图”。 准备数据&#xff1a; 第一个文件为特征的表达文件&#xff0c;第一列为样本&am…

机器人CPP编程基础-05完结The End

非常不可思议……之前四篇博文竟然有超过100的阅读量…… 此文此部分终结&#xff0c;没有继续写下去的必要了。 插入一个分享&#xff1a; 编程基础不重要了&#xff0c;只要明确需求&#xff0c;借助AI工具就能完成一个项目。 当然也不是一次成功&#xff0c;工具使用也需要…

PP模块生产过程检验(工序检验)

质量检验是在一些情形下对物料进行检查的一个操作,用于检验物料是否符合标准。 1.常见检验类型: (1)进货检验(Incoming material Quality Check,IQC) (2) 生产过程检验(In Process Quality Check,IQPC) (3) 最终检验/产品检验(Final Quality Check,FQC) (4)出…

【产品应用】一体化步进伺服电机在自动液体处理工作站中的应用

随着工业自动化的快速发展&#xff0c;自动液体处理工作站在医药、食品、化工等领域中发挥着越来越重要的作用。一体化步进伺服电机作为一种高集成的驱动元件&#xff0c;具有高精度、高速度和高稳定性的特点&#xff0c;被广泛应用于自动液体处理工作站中。本文将详细介绍一体…

同源建模-build loop

对于有残基缺失的晶体结构往往采用同源建模的方式补全&#xff0c;但常规的同源建模方法往往造成非缺失区域残基的挪动&#xff0c;有时我们并不想出现这种状况&#xff0c;尤其是涉及到多个截短体拼合的情况&#xff0c;这时就需要用到约束性同源建模的方法&#xff0c;只对缺…

对一线大厂游戏测试员的访谈实录,带你了解游戏测试

今天采访了一个在游戏行业做测试的同学&#xff0c;他所在的游戏公司是做大型多人在线角色扮演类的游戏&#xff0c;类似传奇游戏。他所在的公司目前有1200多人&#xff0c;是上市公司&#xff0c;目前游戏产品在国内海外都有市场。 因为我是一个对游戏无感的人&#xff0c;所…

户外组网摆脱布线困扰,工业5G网关实现无人值守、远程实时监控

在物联网通信技术发达的2023&#xff0c;网络覆盖对所及之处的全面覆盖&#xff0c;科技发展的促使下很多高危户外场景也在思考如何利用无线技术提高人员安全及现场无人化管理。 煤矿是我们国家不可缺少的重要能源&#xff0c;其开采过程的危险系数也是众所皆知的&#xff0c;…

CANdelaStudio 使用介绍

CANdela Studio使用_哔哩哔哩_bilibili 一.CANdelaStudio使用tips 1.开始菜单打开软件&#xff0c;避免软件字体是德文的 2.打开软件之后&#xff0c;用“Open”打开.cdd或者.cddt文件&#xff0c;不要双击文件打开&#xff0c;这样容易报错 3.查看软件版本信息 4.只有Admin版…

CKA认证真题(3)-- 绝对干货!

目录 前言 15. sidecar边车容器 16. 升级集群 17.备份还原etcd 前言 17道真题难度等级 一级 rbac cpu 扩容 pod指定节点 pv pod日志 排障 查看可用节点 多容器pod 节点维护 二级 networkpolicy service ingress pvc 三级 sidecar 升级集群 备份还原etcd 本系列有三篇博客…

kettle simple-jndi 配置中心

jdbc.properties配置 SampleData/typejavax.sql.DataSource SampleData/driverorg.h2.Driver SampleData/urljdbc:h2:file:./samples/db/sampledb;IFEXISTSTRUE SampleData/userPENTAHO_USER SampleData/passwordPASSWORD SampleDataAdmin/typejavax.sql.DataSource SampleDat…