团队凝聚力_如何通过高凝聚力消除错误

2023-10-23 21:59
文章标签 错误 消除 团队 凝聚力

本文主要是介绍团队凝聚力_如何通过高凝聚力消除错误,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

团队凝聚力

直觉告诉我们,诸如此类的方法具有明显的代码异味:

CompilationTask getTask(Writer out,JavaFileManager fileManager,DiagnosticListener<? super JavaFileObject> diagnosticListener,Iterable<String> options,Iterable<String> classes,Iterable<? extends JavaFileObject> compilationUnits
);

为什么呢? 让我们深入研究这种直觉。 这是来自JavaCompiler Javadoc的示例:

Iterable<? extends JavaFileObject> compilationUnits1 =fileManager.getJavaFileObjectsFromFiles(Arrays.asList(files1));compiler.getTask(null, fileManager, null, null, null, compilationUnits1).call();

那怎么了 我们有很多非常不同类型的参数,这些参数很可能设置为null 。 这降低了上述方法的可重用性,或者按照JArchitect专家的说法 ,我们可能处于“痛苦地带”,因为我们的稳定性较低,抽象度较低 。

  • 稳定性低:在JavaCompiler的未来版本中,很有可能需要另一个非常具体的参数,例如,另一个可Iterable的东西。 这将导致不兼容的API增强
  • 抽象度低:即使上述方法是一种接口方法,也很难多次实现此方法,因为很难以一种有用的方式来实现上述协定。

避免此问题的一种常见方法是使用Petri Kainulainen很好地描述的构建器模式 。

高凝聚力而非“痛苦地带”

也许,对于此编译器API,这可能并不重要。 但是,“高内聚力”(即理想的稳定性/抽象性平衡)的最大价值在于您拥有高度可重用的代码。 这不仅好,因为您的开发人员花费较少的时间来执行特定任务,这还意味着您的代码具有极强的抗错误能力。 例如,从jOOQ的内部检查数据类型转换逻辑:

jOOQ的数据类型转换层次结构

jOOQ的数据类型转换层次结构

以上只是对调用层次结构的摘录,该调用层次结构导致在整个框架中间接使用的单个数据类型转换API。 一切都从那儿开始,所以如果有任何数据类型转换错误,要么是

  • 仅限于上述树表示形式的单个方法/单个叶子
  • 极度全球化

换句话说,任何与数据类型转换有关的错误要么仅仅是表面上的,要么是完全灾难性的。 这基本上意味着在该区域几乎没有回归的可能性,因为任何数据类型转换回归都将立即破坏数百个单元和集成测试。 这是在代码中具有高度凝聚力的主要好处。

如何获得高凝聚力

很简单: 无情地重构 。 您永远不应仅在本地引入新功能。 例如,让我们在这里考虑此修复程序[#3023] DefaultRecordMapper不会将嵌套的UDT映射到嵌套的POJO上 。 因此,我们希望将jOOQ RecordMapperProvider功能应用于嵌套记录。 为什么? 想象一下,我们有一个PERSON表,其中包含ADDRESS和STREET属性的Oracle OBJECT类型。 是的,您也可以将这些数据标准化,但是假设我们正在使用UDT:

CREATE TYPE street_type AS OBJECT (street VARCHAR2(100),no VARCHAR2(30)
);CREATE TYPE address_type AS OBJECT (street street_type,zip VARCHAR2(50),city VARCHAR2(50)
);

现在,我们想将这些数据递归映射到定制的嵌套POJO上:

public class Street {public String street;public String number;
}public class Address {public Street street;public String city;public String country;
}public class Person {public String firstName;public String lastName;public Address address;
}

映射应该可以通过以下方式获得:

// The configuration object contains the
// Mapping algorithm implementation
Person person = DSL.using(configuration).selectFrom(PERSON).where(PERSON.ID.eq(1))// We want to make the mapping algorithm recursive
// to automatically map Address and Street as well.fetchOneInto(Person.class);

记录到POJO的映射已经实现,但是递归没有实现。 当我们实现递归时,我们希望尊重jOOQ 3.1中引入的现有的,上述的可定制映射SPI 。 非常简单,在ConvertAll类型的顶部只有一个实现点

在高度凝聚力的代码库中实现这一点意味着:

  • 我们只需实施一次此新功能
  • 与撰写此博客文章相比,实现此新功能花费的精力更少
  • 记录映射和转换的嵌套将一次性适用于所有用例
  • 我们仅增加了一些令人敬畏的新功能,而其复杂性略有增加(错误的风险较低)

无法预见完美的设计。 它生长缓慢。 今天,我们对Java和集合有很多了解,新的Streams API花费了一段时间。 没有人会从头开始在JDK 1.2中实现如此出色的新API,尽管从那个角度来看,当时它已经相当不错了。

这主要对您意味着两件事:

  • 对于基本的核心代码,重要的是要使其达到较高的内聚性。 如果您是电子银行供应商,则您的付款和经纪业务逻辑应与上面所述完全一样,并具有平衡的稳定性/抽象度比
  • 对于非必需的代码(例如,UI / DB访问),您应该依赖第三方软件,因为其他人将花费更多时间来获得高质量的代码(UI:例如Vaadin , ZK或DB访问:例如Hibernate , jOOQ , Spring Data ,仅举几例)

…并且,如果您要求一个高度凝聚力的框架提供一项新功能,则可能唯一需要做的就是这四行代码 。

参考:在JAVA,SQL和JOOQ博客上, JCG合作伙伴 Lukas Eder提供了如何通过高凝聚力消除错误 。

翻译自: https://www.javacodegeeks.com/2014/03/how-to-eliminate-bugs-through-high-cohesion.html

团队凝聚力

这篇关于团队凝聚力_如何通过高凝聚力消除错误的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

深入理解数据库的 4NF:多值依赖与消除数据异常

在数据库设计中, "范式" 是一个常常被提到的重要概念。许多初学者在学习数据库设计时,经常听到第一范式(1NF)、第二范式(2NF)、第三范式(3NF)以及 BCNF(Boyce-Codd范式)。这些范式都旨在通过消除数据冗余和异常来优化数据库结构。然而,当我们谈到 4NF(第四范式)时,事情变得更加复杂。本文将带你深入了解 多值依赖 和 4NF,帮助你在数据库设计中消除更高级别的异常。 什么是

消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法

消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法   消除安卓SDK更新时的“https://dl-ssl.google.com refused”异常的方法 [转载]原地址:http://blog.csdn.net/x605940745/article/details/17911115 消除SDK更新时的“

【经验交流】修复系统事件查看器启动不能时出现的4201错误

方法1,取得『%SystemRoot%\LogFiles』文件夹和『%SystemRoot%\System32\wbem』文件夹的权限(包括这两个文件夹的所有子文件夹的权限),简单点说,就是使你当前的帐户拥有这两个文件夹以及它们的子文件夹的绝对控制权限。这是最简单的方法,不少老外说,这样一弄,倒是解决了问题。不过对我的系统,没用; 方法2,以不带网络的安全模式启动,运行命令行,输入“ne

Science Robotics 首尔国立大学研究团队推出BBEX外骨骼,实现多维力量支持!

重复性举起物体可能会对脊柱和背部肌肉造成损伤,由此引发的腰椎损伤是工业环境等工作场所中一个普遍且令人关注的问题。为了减轻这类伤害,有研究人员已经研发出在举起任务中为工人提供辅助的背部支撑装置。然而,现有的这类装置通常无法在非对称性的举重过程中提供多维度的力量支持。此外,针对整个人体脊柱的设备安全性验证也一直是一个缺失的环节。 据探索前沿科技边界,传递前沿科技成果的X-robot投稿,来自首尔国立

SQL2005 性能监视器计数器错误解决方法

【系统环境】 windows 2003 +sql2005 【问题状况】 用户在不正当删除SQL2005后会造成SQL2005 性能监视器计数器错误,如下图 【解决办法】 1、在 “开始” --> “运行”中输入 regedit,开启注册表编辑器,定位到 [HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVer

ssm 之事务管理出现错误

JDBC Connection will not be managed by Spring 项目采用的是分布式架构,分别有controller,service,solr三个服务器,之间通过dubbo进行调用,经过测试发现事务配置完以后不能通过spring进行管理,其中两条insert和一条update语句都执行完毕,异常并没有使得事务进行回滚,通过调取debug日志发现“JDBC Conn

Unstructured cannot write mode RGBA as JPEG 错误解决

Unstructured cannot write mode RGBA as JPEG 错误解决 0. 错误详细1. 解决方法 0. 错误详细 Image Extraction Error: Skipping the failed imageTraceback (most recent call last):File "/root/miniconda3/envs/learn-y

收藏:解决 pip install 出现 error: subprocess-exited-with-error 错误的方法

在使用 pip 安装 Python 包时,有时候会遇到 error: subprocess-exited-with-error 错误。这种错误通常是由于 setuptools 版本问题引起的。本文将介绍如何解决这一问题 当你使用 pip install 安装某个 Python 包时,如果 setuptools 版本过高或过低,可能会导致安装过程出错,并出现类似以下错误信息:error: subpr

插件:清理maven错误缓存.bat

插件:https://pan.baidu.com/s/1nHIxHoo1C4MvFlW7QbZe5Q?pwd=7zenhttps://pan.baidu.com/s/1nHIxHoo1C4MvFlW7QbZe5Q?pwd=7zen没错误缓存时: 有错误缓存时:

在幼儿园管理系统中,会议管理申请会议模块:添加会议记录(提交表单)的时候报:404错误!

在幼儿园管理系统(spring MVC)中,会议管理>申请会议模块:添加会议记录的时候报:404错误!不知道为啥找不到,一开始感觉一头雾水,怎么会出现404页面找不到错误那,又检查action,controller等这也没错啊!怎么出现404错误那。经过询问和查找,终于找到原因了。 原因是:添加的有时间字段。 代码: @InitBinder public void in