架构每日一学 15:想要提升协作效率,必须先统一语义

谭sir与二仙桥大爷的经典对话:
谭sir:你该走哪?(非机动车能走机动车道吗?)
大爷:走二仙桥去成华大道(因为我要去成华大道,当然要走二仙桥)
谭sir:能拉吗?(你三轮车能超载吗?)
大爷:能拉,只能拉一点(我的车能拉得动这些货)

我们在很多技术文档中,经常会看到一个“名词解释”的模块,这个模块其实是为了统一语义,使参与各方对于不同名词的理解是在同一个维度上的,避免产生分歧。

统一语义有什么作用呢?

对于架构式而言,统一语义的目标只有一个:项目的需求能够被无损的表达、传递和记录,最终通过架构活动表达出来。

具体来说包含如下几个方面:

  • 架构活动的目标能够清晰地传递并分解给每个参与者

  • 所有参与者的诉求都能够准确地表达和传递

  • 架构活动的目标和所有需求都能反映到架构规划中,并且能无损的拆分到各个需求和子任务中

  • 需求方能得到真实的反馈,从而对架构活动有合理的期望

  • 每个子模块交付并组装之后,能够语义契合、相互兼容,最终符合架构活动的整体目标

为什么会产生语义上的分歧呢?

我们从哲学的角度分析一下产生的根因。

假设物理世界有一个存在,即图中的黄色部分,它是客观存在的。

现在有两个人主体一和主体二,他们对于这个存在分别产生了一个自己的认识,这个认识被称为客体一和客体二,由于客体一和客体二是主体在头脑中形成的认识,不是客观存在,因此不会完全相同。那么对于同一个名词,由于主体所在的语境不同,对同一个客观存在的认识也将不同,这就从根本上造成了语义的差异。

如何消除语义的分歧呢?

一 发现不同的语境。 架构师在每个交互场景中去分析不同角色所在的独立语境,也就是说,先梳理出不同场景,再看这些场景中有哪些角色,这些角色的语境会不会有差别。

二 定义概念。 如果发现在不同的语境中使用相同的名词,却代表不同的含义,这个时候就需要准确地描述这些概念。

三 语义建模。 语义建模就是将不同场景下需要统一的名词给出统一清晰的解释,各自场景下独有的名词则需要保留。

四 反馈修正。 架构师要意识到自己也是人,认知难免存在局限性,所以需要将定义好的语义与各方进行确认和调整,不断纠正。

五 公布、维护和使用统一的语义。 不断使用和打磨实体的定义,最终为企业统一语境,这样从架构设计,到接口定义、模块设计、代码实现等各个环节都会使用统一的语义。

做到以上这些,我们就在企业内部实现了统一语义,能极大减小企业的沟通成本,大家在沟通交流时也会很快进行深入交流,而不是各自理解不了对方说的话。

另外,我们从哲学的角度分析了语义分歧的根源,这也是架构师的一个基本技能,很多情况下找到了问题的根因,也就找到了解决方法。

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

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

相关文章

Redis的数据结构以及对应的使用场景

Redis支持的数据结构包括字符串(String)、列表(List)、哈希(Hash)、集合(Set)、有序集合(Sorted Set)等。这些数据结构在应用开发中扮演着重要的角色,它们各自适用于不同的使用场景和需求。以下是对Redis各数据结构的详细分析及它们的使用场景: 字符串(S…

前端地图中,已知一个点位,获取相同经度或者纬度下的,某个距离的另一个点位

效果图说明:我在圆的中心点位,找到他某个直线距离的另个一点,标注两者之间的距离。如图所示是25000米。 沿纬度方向移动 在相同经度下,计算沿纬度方向移动1000米的新点位: function calculateLatitudePoint(lat, ln…

10-Django项目--Ajax请求

目录 Ajax请求 简单示范 html 数据添加 py文件 html文件 demo_list.html Ajax_data.py 图例 Ajax请求 简单示范 html <input type"button" id"button-one" class"btn btn-success" value"点我"> ​ ​ <script>/…

如何找出你的Windows 10的内部版本和版本号?这里提供两种方法

你过去可能没有真正考虑过Windows内部版本号,除非这是你工作的一部分。以下是如何了解你运行的Windows 10的内部版本、版本和版本号。 内部版本意味着什么 Windows一直使用内部版本。它们代表着对Windows的重大更新。传统上,大多数人都是根据他们使用的主要命名版本(Windo…

使用raise语句抛出异常

自学python如何成为大佬(目录):https://blog.csdn.net/weixin_67859959/article/details/139049996?spm1001.2014.3001.5501 如果某个函数或方法可能会产生异常&#xff0c;但不想在当前函数或方法中处理这个异常&#xff0c;则可以使用raise语句在函数或方法中抛出异常。rai…

学习DHCP动态主机配置协议

目录&#xff1a; dhcp 动态主机配置协议 ftp文件传输协议 dhcp 动态主机配置协议 服务器配置好了地址池 192.168.124.10 -192.168.124.20 客户端从地址池当中随机获取一个ip地址&#xff0c;ip地址会发生变化&#xff0c;使用服务端提供的ip地址&…

与C共舞:让编译更顺滑(2)

1.6 Packed结构体 默认情况下,Zig中的所有结构体字段自然对齐到@alignOf(FieldType)(ABI大小),但没有定义布局。有时,您可能希望具有不符合您的C ABI的定义布局的结构体字段。packed结构体允许您对结构体字段进行极其精确的控制,允许您逐位放置字段。 在packed结构体内…

【MATLAB】概述1

非 ~ 注释 % 定义 >> 数组 赋值 赋值&#xff1a;>> x1 函数 数组 x[x1,x2] 行向量&#xff08;&#xff0c;or ) x[x1;x2] 列向量 x. 转置等间隔向量 1-10 向量&#xff1a;>>xlinspace(1,10,10) 矩阵 矩阵&#xff1a;>>A[1,2,3;4,5,6;7,8,9] …

提取伴奏与人声分离软件:5款手机必备音频软件

在数字音乐的浪潮中&#xff0c;音频处理软件已经成为手机用户不可或缺的工具。特别是在音乐制作、卡拉OK伴奏制作以及日常音频编辑中&#xff0c;人声与伴奏的分离显得尤为重要。本文将为您介绍五款免费且实用的手机音频软件&#xff0c;它们都具有人声与伴奏分离的功能&#…

MoonBit 本周新增类型标注语法、继续进行核心库 API 整理工作

MoonBit更新 类型标注增加了新的语法T? 来表示Option[T] struct Cell[T] {val: Tnext: Cell[T]? }fn f(x : Cell[T]?) -> Unit { ... }相当于 struct Cell[T] {val: Tnext: Option[Cell[T]] }fn f(x : Option[Cell[T]]) -> Unit { ... }旧的Option[T]仍然兼容&…

基于jeecgboot-vue3的Flowable流程-待办任务(三)

因为这个项目license问题无法开源&#xff0c;更多技术支持与服务请加入我的知识星球。 这一部分主要讲委派与转办 1、都调用下面的方法 /*** 操作栏*/function getTableAction(record) {return [{label: 处理,onClick: handleProcess.bind(null, record),},{label: 委派,onC…

C++期末复习

目录 1.基本函数 2.浅拷贝和深拷贝 3.初始化列表 4.const关键字的使用 5.静态成员变量和成员函数 6.C对象模型 7.友元 8.自动类型转换 9.继承 1.基本函数 &#xff08;1&#xff09;构造函数&#xff0c;这个需要注意的就是我们如果使用类名加括号&#xff0c;括号里面…

vivado BD_PIN、BD_PORT

BD_PIN 描述 块设计引脚或bd_pin对象是块设计上的逻辑连接点 单间牢房块设计引脚允许抽象单元的内部逻辑&#xff0c;并且 简化以便于使用。引脚可以是标量引脚或总线引脚&#xff0c;并且可以出现在层次结构上 块设计单元或叶级单元。 相关对象 如图所示&#xff0c;块设计引脚…

RDMA (1)

RDMA是什么 Remote Direct Memory Access(RDMA)是用来给有高速需求的应用释放网络消耗的。 RDMA在网络的两个应用之间进行低延迟,高吞吐的内存对内存的直接数据通信。 InfiniBand需要部署独立的协议。 RoCE(RDMA over Converged Ethernet),也是由InfiniBand Trade Associat…

可以举例说明 Vue 的模板语法在实际开发中的应用场景吗?

1&#xff1a;插值和指令: 场景: 在一个博客页面上显示文章标题和内容。 应用: 使用 {{ title }} 插值来显示文章标题。 使用 v-html 指令来渲染富文本格式的文章内容。 2&#xff1a;事件处理: 场景: 在一个按钮上添加点击事件,弹出提示框。 应用: 使用 click 指令绑定点击事…

【Java基础】线程的概念、特点及创建线程的三种方式

线程概念 程序&#xff1a; 是指令和数据的有序集合&#xff0c;其本身没有任何运行的含义&#xff0c;是一个静态的概念。 进程&#xff1a; 是执行程序的一次执行过程&#xff0c;她是一个动态的概念&#xff0c;是系统资源分配的单位。正在运行的程序在内存中开辟相应的空间…

2024-万相台 无界 运营实战4.0最新版,店铺 运营推广必修 理论+实操

课程内容 基 础 操 作 直通车选择投放关键词 直通车怎么选择投放人群 直通车抢位助手怎么用 直通车创意如何设置投放 直通车报表的解读分析 直通车低价引流 智能计划投放技巧 均匀测款计划技巧 周期性投放计划技巧 词包计划投放方案 中心词计划投放方案 转 化 率 …

2024拼多多 最新理论+实战干货,从入门到精通全链路多角度学习-7节课

基于最新规则理论结合实际的干货 课程内容&#xff1a; 01 2024年多多防比价新规则破局理论课与实操课.mp4 02 24年多多强付费第二节课基础内功.mp4 03 24年多多强付费第三节课直通车实操 .mp4 04 24年多多强付费第一节课市场定价格段,mp4 05 24年多多自然流第一节课市场…

限流开关:HC5504,70mΩ,5V USB 高侧可调门限限流负载开关,供应USB总线/自供电集线器USB周边、笔记本电脑,平板电脑、电池充电器

限流开关&#xff1a; HC5504&#xff1a;70mΩ&#xff0c;5V USB 高侧可调门限限流负载开关 概述&#xff1a;HC5504是一款适用于5V应用的可调限流门限的USB接口输出保护芯片。芯片内部集成了过流保护、短路保护、过温保护、欠压保护等功能&#xff0c;在输出发生过流、短路…

【Java】如何让系统抗住双十一的预约抢购活动?

一、问题解析 在大促活动期间&#xff0c;“预约抢购”已经是各大电商平台的主要促销手段&#xff0c;京东自然也会和一些大的供应商合作&#xff0c;推出一些低价的爆款产品&#xff0c;比如 2019 年的 “1499 元抢购飞天茅台”活动&#xff0c;就让很多人每天准时准点拿着手…