springboot策略解决低耦合 函数计算调用问题

本文主要是介绍springboot策略解决低耦合 函数计算调用问题,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

当然,我理解您现在可能感到有些混乱。让我为您创建一个详细的程序执行流程图,以帮助您更好地理解整个过程。

策略选择和计算
前端请求处理
CalculationStrategyFactory初始化
应用启动
扫描组件
注入策略列表
遍历策略列表
获取类名
转为小写
策略实例
HTTP POST
解析请求体
获取toolname
根据toolname查找
返回策略实例
返回计算结果
调用CalculationStrategyFactory.getStrategy
从strategies Map中获取策略
执行选定策略的calculate方法
OneShopToolController返回结果给前端
OneShopToolController接收请求
前端发送计算请求
创建CalculationRequest对象
调用OneShopToolService.calculateResult
处理每个策略
移除'CalculationStrategy'后缀
作为Map的key
作为Map的value
存入strategies Map
发现并实例化所有CalculationStrategy实现
启动Spring应用
创建CalculationStrategyFactory
初始化strategies Map

这个详细的流程图展示了整个程序的执行过程,从应用启动到最终计算结果的返回。让我为您解释各个主要阶段:

  1. 应用启动

    • Spring应用启动,扫描并实例化所有 CalculationStrategy 的实现。
    • 创建 CalculationStrategyFactory 并注入所有策略实例。
  2. CalculationStrategyFactory初始化

    • 工厂类遍历所有注入的策略实例。
    • 对每个策略,获取其类名,移除 “CalculationStrategy” 后缀,转为小写作为key。
    • 将策略名(key)和策略实例(value)存入 strategies Map。
  3. 前端请求处理

    • 前端发送计算请求到后端。
    • OneShopToolController 接收请求,解析为 CalculationRequest 对象。
    • 调用 OneShopToolServicecalculateResult 方法。
  4. 策略选择和计算

    • CalculationRequest 中获取 toolname。
    • 调用 CalculationStrategyFactorygetStrategy 方法。
    • 根据 toolname 从 strategies Map 中获取对应的策略实例。
    • 执行选定策略的 calculate 方法。
    • 将计算结果返回给前端。

这个流程图清晰地展示了系统的各个组件是如何协同工作的:

  • Spring 如何管理和注入依赖
  • 策略工厂如何初始化和管理不同的计算策略
  • 控制器如何处理请求并调用相应的服务
  • 服务如何使用策略工厂选择正确的策略
  • 最终如何执行计算并返回结果

通过这个流程图,您应该能更好地理解整个系统的工作原理,包括策略模式的应用,以及Spring框架在其中扮演的角色。如果您对任何特定部分还有疑问,请随时询问,我很乐意进一步解释。

这篇关于springboot策略解决低耦合 函数计算调用问题的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

好题——hdu2522(小数问题:求1/n的第一个循环节)

好喜欢这题,第一次做小数问题,一开始真心没思路,然后参考了网上的一些资料。 知识点***********************************无限不循环小数即无理数,不能写作两整数之比*****************************(一开始没想到,小学没学好) 此题1/n肯定是一个有限循环小数,了解这些后就能做此题了。 按照除法的机制,用一个函数表示出来就可以了,代码如下

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu