开发,从需求出发 · 之五 麦克斯韦妖

2024-03-09 06:40

本文主要是介绍开发,从需求出发 · 之五 麦克斯韦妖,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

麦克斯韦妖(Maxwell's demon),是在物理学中假想的妖,能探测并控制单个分子的运动,于1871年由英国物理学家詹姆斯·麦克斯韦为了说明违反热力学第二定律的可能性而设想的。


好吧,让我们充当一次麦克斯韦妖,探测和控制单个模块/方法的工作~~~

先上三张图:

传统状态:

1 由于上层接口依赖于下层接口的实现,因此,开发顺序是自下而上开发,底层接口没有实现,上层无法进行有效的开发;

2 SearchService 的测试工作依赖于底层接口的实现,获得的输入不可控,因此在输出存在异常的情况下,无法界定是内部逻辑问题还是输入异常

3 确定输入异常的情况下,需要逐个排查底层接口


模拟状态:

1 由于我们确定 LuceneDAOMock 和 MysqlDAOMock 的运行是正确的,

2 因此LuceneDAO 和 MysqlDAO 的输出也是正确的,

3 SearchService如果逻辑是正确的,那么,其输出也必定是正确的,

4 但是,如果输出不是预期的数值,那么说明,SearchService的实现类 SearchServiceInRealBiz 必定有问题,而且,必定是自身的问题造成的。

5 SearchService接口的实现工作室完全可以和 它所依赖的下一层分离并行的,

6 这种模式下是支持自上而下的开发的——亦即我所说的“从需求出发”


混合状态:

1 混合状态是模拟状态的进行时状态

2 开发过程中,保持其他模块的模拟状态,只选取一个模块进行真实业务逻辑的实现

3 在多个粒度和层面上进行针对该模块的测试

4 将该模块切换为模拟状态,挑选另一个模块重复2-3的开发和测试工作。

5 所有模块实现完毕,同时,也测试完毕。


至此,麦克斯韦妖成功完成了它的工作~~~~


那么,我前面实现的BeanFactory 或者spring 的 依赖注入的作用体现在哪里呢?

——就是 模拟模块和真实模块的注入和切换。

我基于spring.xml的形式说明:


STEP 1,开发和测试 SearchService

SearchService 的实现类: SearchServiceInRealBiz

<?xml version="1.0" encoding="UTF-8"?>
<beans >//模拟<bean id="luceneDAO" class="cn.com.sitefromscrath.dao.LuceneDAOMock" />//模拟<bean id="mysqlDAO" class="cn.com.sitefromscrath.dao.MysqlDAOMock" /> <bean id="searchService" class="cn.com.sitefromscrath.service.SearchServiceInRealBiz"><constructor-arg index="1" ref="luceneDAO" /><constructor-arg index="2" ref="mysqlDAO" /></bean>  </beans>

STEP 2, 开发和测试LuceneDAO

<?xml version="1.0" encoding="UTF-8"?>
<beans >//开发测试<bean id="luceneDAO" class="cn.com.sitefromscrath.dao.LuceneDAOReal" />//模拟<bean id="mysqlDAO" class="cn.com.sitefromscrath.dao.MysqlDAOMock" /> //模拟<bean id="searchService" class="cn.com.sitefromscrath.service.SearchServiceMock"><constructor-arg index="1" ref="luceneDAO" /><constructor-arg index="2" ref="mysqlDAO" /></bean>  </beans>

STEP 3,开发和测试MysqlDAO

<?xml version="1.0" encoding="UTF-8"?>
<beans >//模拟<bean id="luceneDAO" class="cn.com.sitefromscrath.dao.LuceneDAOMock" />//开发测试<bean id="mysqlDAO" class="cn.com.sitefromscrath.dao.MysqlDAOReal" /> //模拟<bean id="searchService" class="cn.com.sitefromscrath.service.SearchServiceMock"><constructor-arg index="1" ref="luceneDAO" /><constructor-arg index="2" ref="mysqlDAO" /></bean>  </beans>

开发测试同步完成。


不仅仅开发如此,在以后的系统维护过程中,一旦发生异常,是比较容易排查错误的原因的,如果你能获得真实环境下的异常输入,那么,debug将会相当快速高效。

你所要做的只不过是像麦克斯韦妖一样——把不同的分子放到不同的格子里面去

我确信,当我启动tomcat,打开页面,并进行查询操作的时候,得到的页面展示内容是正确的,符合预期的:)


OK了:)

基于sitefromscratch这个搜索网站项目的讨论到此结束,在接下来的章节里,我打算引申到更广泛的领域里面去。

to be continued.............

这篇关于开发,从需求出发 · 之五 麦克斯韦妖的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

VSCode开发中有哪些好用的插件和快捷键

《VSCode开发中有哪些好用的插件和快捷键》作为全球最受欢迎的编程工具,VSCode的快捷键体系是提升开发效率的核心密码,:本文主要介绍VSCode开发中有哪些好用的插件和快捷键的相关资料,文中... 目录前言1、vscode插件1.1 Live-server1.2 Auto Rename Tag1.3

Agent开发核心技术解析以及现代Agent架构设计

《Agent开发核心技术解析以及现代Agent架构设计》在人工智能领域,Agent并非一个全新的概念,但在大模型时代,它被赋予了全新的生命力,简单来说,Agent是一个能够自主感知环境、理解任务、制定... 目录一、回归本源:到底什么是Agent?二、核心链路拆解:Agent的"大脑"与"四肢"1. 规划模

Python+wxPython开发一个文件属性比对工具

《Python+wxPython开发一个文件属性比对工具》在日常的文件管理工作中,我们经常会遇到同一个文件存在多个版本,或者需要验证备份文件与源文件是否一致,下面我们就来看看如何使用wxPython模... 目录引言项目背景与需求应用场景核心需求运行结果技术选型程序设计界面布局核心功能模块关键代码解析文件大

C++多线程开发环境配置方法

《C++多线程开发环境配置方法》文章详细介绍了如何在Windows上安装MinGW-w64和VSCode,并配置环境变量和编译任务,使用VSCode创建一个C++多线程测试项目,并通过配置tasks.... 目录下载安装 MinGW-w64下载安装VS code创建测试项目配置编译任务创建 tasks.js

一文详解Python如何开发游戏

《一文详解Python如何开发游戏》Python是一种非常流行的编程语言,也可以用来开发游戏模组,:本文主要介绍Python如何开发游戏的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录一、python简介二、Python 开发 2D 游戏的优劣势优势缺点三、Python 开发 3D

基于Python开发Windows自动更新控制工具

《基于Python开发Windows自动更新控制工具》在当今数字化时代,操作系统更新已成为计算机维护的重要组成部分,本文介绍一款基于Python和PyQt5的Windows自动更新控制工具,有需要的可... 目录设计原理与技术实现系统架构概述数学建模工具界面完整代码实现技术深度分析多层级控制理论服务层控制注

Java中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例解析

《Java中的分布式系统开发基于Zookeeper与Dubbo的应用案例解析》本文将通过实际案例,带你走进基于Zookeeper与Dubbo的分布式系统开发,本文通过实例代码给大家介绍的非常详... 目录Java 中的分布式系统开发基于 Zookeeper 与 Dubbo 的应用案例一、分布式系统中的挑战二

基于Go语言开发一个 IP 归属地查询接口工具

《基于Go语言开发一个IP归属地查询接口工具》在日常开发中,IP地址归属地查询是一个常见需求,本文将带大家使用Go语言快速开发一个IP归属地查询接口服务,有需要的小伙伴可以了解下... 目录功能目标技术栈项目结构核心代码(main.go)使用方法扩展功能总结在日常开发中,IP 地址归属地查询是一个常见需求:

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

SpringBoot 多环境开发实战(从配置、管理与控制)

《SpringBoot多环境开发实战(从配置、管理与控制)》本文详解SpringBoot多环境配置,涵盖单文件YAML、多文件模式、MavenProfile分组及激活策略,通过优先级控制灵活切换环境... 目录一、多环境开发基础(单文件 YAML 版)(一)配置原理与优势(二)实操示例二、多环境开发多文件版