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

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

相关文章

Python错误AttributeError: 'NoneType' object has no attribute问题的彻底解决方法

《Python错误AttributeError:NoneTypeobjecthasnoattribute问题的彻底解决方法》在Python项目开发和调试过程中,经常会碰到这样一个异常信息... 目录问题背景与概述错误解读:AttributeError: 'NoneType' object has no at

SpringBoot+Docker+Graylog 如何让错误自动报警

《SpringBoot+Docker+Graylog如何让错误自动报警》SpringBoot默认使用SLF4J与Logback,支持多日志级别和配置方式,可输出到控制台、文件及远程服务器,集成ELK... 目录01 Spring Boot 默认日志框架解析02 Spring Boot 日志级别详解03 Sp

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.

如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socket read timed out的问题

《如何解决Druid线程池Cause:java.sql.SQLRecoverableException:IO错误:Socketreadtimedout的问题》:本文主要介绍解决Druid线程... 目录异常信息触发场景找到版本发布更新的说明从版本更新信息可以看到该默认逻辑已经去除总结异常信息触发场景复

Python struct.unpack() 用法及常见错误详解

《Pythonstruct.unpack()用法及常见错误详解》struct.unpack()是Python中用于将二进制数据(字节序列)解析为Python数据类型的函数,通常与struct.pa... 目录一、函数语法二、格式字符串详解三、使用示例示例 1:解析整数和浮点数示例 2:解析字符串示例 3:解

CentOS 7 YUM源配置错误的解决方法

《CentOS7YUM源配置错误的解决方法》在使用虚拟机安装CentOS7系统时,我们可能会遇到YUM源配置错误的问题,导致无法正常下载软件包,为了解决这个问题,我们可以替换YUM源... 目录一、备份原有的 YUM 源配置文件二、选择并配置新的 YUM 源三、清理旧的缓存并重建新的缓存四、验证 YUM 源

python3 pip终端出现错误解决的方法详解

《python3pip终端出现错误解决的方法详解》这篇文章主要为大家详细介绍了python3pip如果在终端出现错误该如何解决,文中的示例方法讲解详细,感兴趣的小伙伴可以跟随小编一起了解一下... 目录前言一、查看是否已安装pip二、查看是否添加至环境变量1.查看环境变量是http://www.cppcns

python进行while遍历的常见错误解析

《python进行while遍历的常见错误解析》在Python中选择合适的遍历方式需要综合考虑可读性、性能和具体需求,本文就来和大家讲解一下python中while遍历常见错误以及所有遍历方法的优缺点... 目录一、超出数组范围问题分析错误复现解决方法关键区别二、continue使用问题分析正确写法关键点三

Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题

《Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题》:本文主要介绍Ubuntu上手动安装Go环境并解决“可执行文件格式错误”问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未... 目录一、前言二、系统架构检测三、卸载旧版 Go四、下载并安装正确版本五、配置环境变量六、验证安装七、常见

正则表达式r前缀使用指南及如何避免常见错误

《正则表达式r前缀使用指南及如何避免常见错误》正则表达式是处理字符串的强大工具,但它常常伴随着转义字符的复杂性,本文将简洁地讲解r的作用、基本原理,以及如何在实际代码中避免常见错误,感兴趣的朋友一... 目录1. 字符串的双重翻译困境2. 为什么需要 r?3. 常见错误和正确用法4. Unicode 转换的