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

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

相关文章

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

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

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

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

解决tomcat启动时报Junit相关错误java.lang.ClassNotFoundException: org.junit.Test问题

《解决tomcat启动时报Junit相关错误java.lang.ClassNotFoundException:org.junit.Test问题》:本文主要介绍解决tomcat启动时报Junit相... 目录tomcat启动时报Junit相关错误Java.lang.ClassNotFoundException

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

C/C++错误信息处理的常见方法及函数

《C/C++错误信息处理的常见方法及函数》C/C++是两种广泛使用的编程语言,特别是在系统编程、嵌入式开发以及高性能计算领域,:本文主要介绍C/C++错误信息处理的常见方法及函数,文中通过代码介绍... 目录前言1. errno 和 perror()示例:2. strerror()示例:3. perror(

Go标准库常见错误分析和解决办法

《Go标准库常见错误分析和解决办法》Go语言的标准库为开发者提供了丰富且高效的工具,涵盖了从网络编程到文件操作等各个方面,然而,标准库虽好,使用不当却可能适得其反,正所谓工欲善其事,必先利其器,本文将... 目录1. 使用了错误的time.Duration2. time.After导致的内存泄漏3. jsO

Python中ModuleNotFoundError: No module named ‘timm’的错误解决

《Python中ModuleNotFoundError:Nomodulenamed‘timm’的错误解决》本文主要介绍了Python中ModuleNotFoundError:Nomodulen... 目录一、引言二、错误原因分析三、解决办法1.安装timm模块2. 检查python环境3. 解决安装路径问题

如何解决mysql出现Incorrect string value for column ‘表项‘ at row 1错误问题

《如何解决mysql出现Incorrectstringvalueforcolumn‘表项‘atrow1错误问题》:本文主要介绍如何解决mysql出现Incorrectstringv... 目录mysql出现Incorrect string value for column ‘表项‘ at row 1错误报错

SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法

《SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法》本文主要介绍了SpringBoot项目启动错误:找不到或无法加载主类的几种解决方法,具有一定的参考价值,感兴趣的可以了解一下... 目录方法1:更改IDE配置方法2:在Eclipse中清理项目方法3:使用Maven命令行在开发Sprin