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

2024-06-05 01:04

本文主要是介绍架构每日一学 15:想要提升协作效率,必须先统一语义,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

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

统一语义有什么作用呢?

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

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

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

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

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

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

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

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

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

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

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

如何消除语义的分歧呢?

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

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

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

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

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

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

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

这篇关于架构每日一学 15:想要提升协作效率,必须先统一语义的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1031631

相关文章

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

PowerShell中15个提升运维效率关键命令实战指南

《PowerShell中15个提升运维效率关键命令实战指南》作为网络安全专业人员的必备技能,PowerShell在系统管理、日志分析、威胁检测和自动化响应方面展现出强大能力,下面我们就来看看15个提升... 目录一、PowerShell在网络安全中的战略价值二、网络安全关键场景命令实战1. 系统安全基线核查

Knife4j+Axios+Redis前后端分离架构下的 API 管理与会话方案(最新推荐)

《Knife4j+Axios+Redis前后端分离架构下的API管理与会话方案(最新推荐)》本文主要介绍了Swagger与Knife4j的配置要点、前后端对接方法以及分布式Session实现原理,... 目录一、Swagger 与 Knife4j 的深度理解及配置要点Knife4j 配置关键要点1.Spri

mysql中的服务器架构详解

《mysql中的服务器架构详解》:本文主要介绍mysql中的服务器架构,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、mysql服务器架构解释3、总结1、背景简单理解一下mysqphpl的服务器架构。2、mysjsql服务器架构解释mysql的架

Mysql中isnull,ifnull,nullif的用法及语义详解

《Mysql中isnull,ifnull,nullif的用法及语义详解》MySQL中ISNULL判断表达式是否为NULL,IFNULL替换NULL值为指定值,NULLIF在表达式相等时返回NULL,用... 目录mysql中isnull,ifnull,nullif的用法1. ISNULL(expr) → 判

k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)

《k8s上运行的mysql、mariadb数据库的备份记录(支持x86和arm两种架构)》本文记录在K8s上运行的MySQL/MariaDB备份方案,通过工具容器执行mysqldump,结合定时任务实... 目录前言一、获取需要备份的数据库的信息二、备份步骤1.准备工作(X86)1.准备工作(arm)2.手

统一返回JsonResult踩坑的记录

《统一返回JsonResult踩坑的记录》:本文主要介绍统一返回JsonResult踩坑的记录,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录统一返回jsonResult踩坑定义了一个统一返回类在使用时,JsonResult没有get/set方法时响应总结统一返回

Maven 插件配置分层架构深度解析

《Maven插件配置分层架构深度解析》:本文主要介绍Maven插件配置分层架构深度解析,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Maven 插件配置分层架构深度解析引言:当构建逻辑遇上复杂配置第一章 Maven插件配置的三重境界1.1 插件配置的拓扑

gradle第三方Jar包依赖统一管理方式

《gradle第三方Jar包依赖统一管理方式》:本文主要介绍gradle第三方Jar包依赖统一管理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录背景实现1.顶层模块build.gradle添加依赖管理插件2.顶层模块build.gradle添加所有管理依赖包

Java异常架构Exception(异常)详解

《Java异常架构Exception(异常)详解》:本文主要介绍Java异常架构Exception(异常),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. Exception 类的概述Exception的分类2. 受检异常(Checked Exception)