跟着美团学设计模式(感处)

news2024/12/28 3:49:50

读了着篇文章之后发现真的是,你的思想,你的思维是真的比比你拥有什么技术要强的。

注 

开闭原则

开闭原则(Open-Closed Principle)是面向对象设计中的基本原则之一,它的定义是:一个软件实体应该对扩展开放,对修改关闭。也就是说,在软件的生命周期内,当需要对软件进行修改时,应该通过扩展软件实体的行为来实现变化,而不是通过修改已有的代码来实现变化。

开闭原则的目的是提高软件的可复用性和可维护性。在软件开发过程中,随着业务需求的变化,软件需求可能会发生变化,而开闭原则可以帮助我们避免对现有代码的修改,从而减少引入新错误和重构整个功能的风险

迪米特法则

迪米特法则(Law of Demeter,LoD)是一种面向对象设计原则,也被称为最少知识原则(Least Knowledge Principle,LKP)。它指出一个软件实体应当尽可能少地与其他实体发生相互作用。如果一个系统符合迪米特法则,那么当其中某一个模块发生修改时,就会尽量少地影响其他模块,扩展会相对容易,这是对软件实体之间通信的限制,迪米特法则要求限制软件实体之间通信的宽度和深度。

迪米特法则的核心思想是降低组件之间的耦合度,提高代码的松耦合性,从而使得代码更易于维护、扩展和重构。在迪米特法则的指导下,一个类应该尽可能少地与其他类发生相互作用,尽量避免直接相互依赖,而是通过接口、抽象类等机制来进行通信,使得类与类之间的联系更加松散,易于维护和扩展。

迪米特法则的命名来源于古希腊神话中的人物狄米特(Demeter),她是希腊神话中的农业女神,也是宙斯的姐姐。在这个神话中,狄米特规定了农业的生产规律,类似于迪米特法则规定了软件实体之间的通信规律。

围绕高内聚和低耦合两个方面,然后结合设计模式

围绕高内聚和低耦合两个方面,然后结合设计模式

围绕高内聚和低耦合两个方面,然后结合设计模式

奖励发放策略

第一天,老师问小明:“你知道活动营销吗?”
“这我知道,活动营销是指企业通过参与社会关注度高的已有活动,或整合有效的资
源自主策划大型活动,从而迅速提高企业及其品牌的知名度、美誉度和影响力,常见
的比如有抽奖、红包等。”
老师点点头:“是的。我们假设现在就要做一个营销,需要用户参与一个活动,然后完
成一系列的任务,最后可以得到一些奖励作为回报。活动的奖励包含美团外卖、酒旅
和美食等多种品类券,现在需要你帮忙设计一套奖励发放方案。”
因为之前有过类似的开发经验,拿到需求的小明二话不说开始了编写起了代码:

 小明很快写好了 Demo,然后发给老师看。
“假如我们即将接入新的打车券,这是否意味着你必须要修改这部分代码?”老师
问道。

一眼就看出了端详。这不满足我们设计原则中的开闭原则,和迪米特原则。

那我们该如何进行优化呢?

这个案例就可以用适配器和策略模式来调优

策略模式 | 菜鸟教程   适配器模式 | 菜鸟教程

先通过这个策略模式优化了变成如下代码

 然后,小明创建策略模式的环境类,并供奖励服务调用:

小明的代码经过优化后,虽然结构和设计上比之前要复杂不少,但考虑到健壮性和拓展性,还是非常值得的。

策略类是有状态的模型吗?如果不是是否可以考虑做成单例的?

环境类的获取策略方法职责很明确,但是依然没有做到完全对修改封闭

解决 :可以将策略类单例化以减少开销,并实现自注册的功能彻底解决分支判断

小明列出单例模式的要点:
单例模式  设计模式属于创建型模式,它提供了一种创建对象的最佳方式。
这种模式涉及到一个单一的类,该类负责创建自己的对象,同时确保只有单个对象被
创建。这个类提供了一种访问其唯一的对象的方式,可以直接访问,不需要实例化该
类的对象。

 最终,小明在策略环境类中使用一个注册表来记录各个策略类的注册信息,并提供接
口供策略类调用进行注册。同时使用饿汉式单例模式去优化策略类的设计:

 

 

最终,小明设计完成的结构类图如下:

如果使用了 Spring 框架,还可以利用 Spring 的 Bean 机制来代替上述的部分设计,
直接使用 @Component 和 @PostConstruct 注解即可完成单例的创建和注册,代
码会更加简洁。

一些自己的思考

在设计你的业务逻辑的时候,或者写你的逻辑的代码,一定一定要思考设计模式-创造型模式,结构型模式,和行为型模式,还有下面的

J2EE 模式
这些设计模式特别关注表示层

我们该用什么。怎么调优

任务模型的设计

现在,我想让你去完成任务模型的设计。你需要重点关注状态的流转变更,以及状态变更后的消息通知。而上一个奖励发放策略貌似是状态的一个确定。

小明呢接下了难题,他首先定义了一套任务状态的枚举和行为的枚举

然后,小明对开始编写状态变更功能

很明显上述代码 依然存在有上一个例子的问题。

问题是什么

第一,方法中使用条件判断来控制语句,但是当条件复杂或者状态太多时,条件判
断语句会过于臃肿,可读性差,且不具备扩展性,维护难度也大。且增加新的状态时
要添加新的 if-else 语句,这违背了开闭原则,不利于程序的扩展

第二,任务类不够高内聚,它在通知实现中感知了其他
领域或模块的模型,如活动和任务管理器,这样代码的耦合度太高,不利于扩展

优化

首先是状态流转的控制可以使用状态模式,其次,任务完成时的通知可以用到观察者模式

观察者模式 | 菜鸟教程 状态模式 | 菜鸟教程

根据状态模式的定义,小明将 TaskState 枚举类扩展成多个状态类,并具备完成状
态的流转的能力;然后优化了任务类的实现:

 小明欣喜地看到,经过状态模式处理后的任务类的耦合度得到降低,符合开闭原则。
状态模式的优点在于符合单一职责原则,状态类职责明确,有利于程序的扩展。这样设计的代价是状态类的数目增加了,因此状态流转逻辑越复杂、需要处理的动作
越多,越有利于状态模式的应用。

小明首先设计好抽象目标和抽象观察者,然后将活动和任务管理器的接收通知功能定
制成具体观察者:

 最后,小明将任务进行状态类优化成使用通用的通知方法,并在任务初始态执行状态
流转时定义任务进行态所需的观察者

 

最终,小明设计完成的结构类图如下

 通过观察者模式,小明让任务状态和通知方实现松耦合(实际上观察者模式还没能做到完全的解耦,如果要做进一步的解耦可以考虑学习并使用发布 - 订阅模式)

活动的迭代重构

活动模型的特点在于其组成部分较多,小明原先的活动模型的构建方式是这样的

 

上述代码得问题主要表现在

活动的构造组件较多,导致可以组合的构造函数太多,尤其是在模型增加字段时还需
要去修改构造函数

部分组件的构造存在一定的顺序关系,但是当前的实现没有体现顺序,导致构造逻辑
比较混乱,并且存在部分重复的代码

这种情况呢?我们使用创建者模式。

在实际的应用中,如果字段类型多,
同时各个字段只需要简单的赋值,可以直接引用 Lombok 的 @Builder 注解来实现
轻量的建造者。

重构完活动构建的设计后,小明开始对参加活动方法增加风控。最简单的方式肯定是

直接修改目标方法。但是是有的活动需要风控有的不需要。这时候我们就用了装饰者模式。来进行风控。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/891970.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Redis——list类型详解

概要 Redis中的list类型相当于双端队列,支持头插,头删,尾插,尾删,并且列表中的内容是可以重复的。 如果搭配使用rpush和lpop,那么就相当于队列 如果搭配使用rpush和rpop,那么就相当于栈 lpu…

皮爷咖啡基于亚马逊云科技的数据架构,加速数据治理进程

皮爷咖啡(Peet’s Coffee)是美国精品咖啡品牌,于2017年进入中国,为中国消费者带来传统经典咖啡饮品,并特别呈现更加丰富的品质咖啡饮品体验。通过深入应用亚马逊云科技云原生数据库产品Amazon Redshift以及Amazon DMS等…

开源的密码学工具库:openssl安装在docker容器环境Linux(ubuntu18.04)

OpenSSL(Open Secure Socket Layer)是一个开源的密码学工具库,它提供了一系列的加密、解密、认证和通信安全相关的功能。OpenSSL 最初是为了支持安全的网络通信而设计的,但后来它的功能逐渐扩展到了许多不同的领域,包括…

【SSL证书】阿里云免费 SSL证书申请 + nginx 部署全解

一、环境 二、步骤 三、实战 Stage 1:申请免费证书 1. 进入 - 数字证书管理服务(SSL证书) 2. 创建证书 3. 申请证书 Stage 2:域名解析 1. 进入 - 域名管理 2. 点击 - 域名 3. 点击 - 域名解析 4. 点击 - 添加记录 5. 返回 - 数…

润和软件HopeStage操作系统正式上架阿里云、华为云、腾讯云商店

近日,润和软件HopeStage操作系统正式上架阿里云、华为云、腾讯云商店。 随着科技的发展,云服务成为现代社会信息和资讯的交换、共享、存储、检索、应用等重要方式。阿里云、华为云、腾讯云作为我国云服务市场三巨头,其云商店产品全面覆盖云、…

spring(15) SpringBoot启动过程

目录 一、过程简介二、过程流程图三、源码分析1、运行 SpringApplication.run() 方法2、确定应用程序类型3、加载所有的初始化器4、加载所有的监听器5、设置程序运行的主类6、开启计时器7、将 java.awt.headless 设置为 true8、获取并启用监听器9、设置应用程序参数10、准备环境…

【Golang系统开发】搜索引擎(2) 压缩词典

写在前面 这篇文章我们就给出一系列的数据结构,使得词典能达到越来越高的压缩比。当然,和倒排索引记录表的大小相比,词典只占据了非常小的空间。那么为什么要对词典进行压缩呢? 这是因为决定信息检索系统的查询响应时间的一个重…

《计算机网络:自顶向下方法》第五章--网络层:控制平面

控制平面作为一种网络范围的逻辑,不仅控制沿着从源主机到目的主机的端到端路径间的路由器如何转发数据报,而且控制网络层组件和服务如何配置和管理 传统上,控制平面功能与数据平面的转发功能在一起实现,在路由器中作为统一的整体…

IDEA 如何制作代码补丁?IDEA 生成 patch 和使用 patch

什么是升级补丁? 比如你本地修复的 bug,需要把增量文件发给客户,很多场景下大家都需要手工整理修改的文件,并整理好目录,这个很麻烦。那有没有简单的技巧呢?看看 IDEA 生成 patch 和使用 patch 的使用。 介…

Kafka—工作流程、如何保证消息可靠性

什么是kafka? 分布式事件流平台。希望不仅仅是存储数据,还能够数据存储、数据分析、数据集成等功能。消息队列(把数据从一方发给另一方),消息生产好了但是消费方不一定准备好了(读写不一致)&am…

常量(constant)

1、概述 常量:是指在Java程序运行期间固定不变的数据。 2、分类 类型含义数据举例整数常量所有的整数0,1,567,-9 小数常量 (浮点数常量) 所有的小数0.0,-0.1,2.55字符常量单引号引起…

Python量化交易11——使用AKShare获取公司财务数据

AKshare库是一个很好用的金融数据获取的API,股票的数据很全面,还有很多别的数据: 链接:AKShare 股票数据 — AKShare 1.10.85 文档 他们获取来源都是东方财富网或者巨潮网等,都会写上的。 本次教大家怎么用AKshare获取…

第九章 动态规划part11(代码随想录)

123.买卖股票的最佳时机III 给定一个数组,它的第 i 个元素是一支给定的股票在第 i 天的价格。 设计一个算法来计算你所能获取的最大利润。你最多可以完成 两笔 交易。 注意:你不能同时参与多笔交易(你必须在再次购买前出售掉之前的股票&…

vscode如何汉化

首先我们到vscode官网下载 链接如下: Visual Studio Code - Code Editing. Redefined 根据自己需要的版本下载就好 下载并且安装完毕之后 运行vscode 然后按快捷键 CTRLSHIFTX 打开安装扩展界面 搜索简体中文 安装就可以了 谢谢大家观看

Matplotlib数据可视化(一)

目录 1.Matplotlib简介 2.Matplotlib绘图基础 2.1 创建画布与子图 2.2 添加画布属性 2.3 绘图的保存与显示 1.Matplotlib简介 Matplotlib是一个用于绘制数据可视化图表的Python库。它提供了广泛的功能和灵活性,可以创建各种类型的图表,包括折线图、…

Microsoft Edge浏览器开启ChatAI扩展

ChatAi每日可以免费使用5次,购买每月8.8,每年88。价格还不算贵 安装扩展过程: 打开 Microsoft Edge浏览器,点击右上角三个点,在扩展中选择加载项,在Microsoft Edge加载项中搜索openai,选择Chat…

kafka晋升之路-理论+场景

kafka晋升之路 一:故事背景二:核心概念2.1 系统架构2.2 生产者(Producer)2.2.1 生产者分区2.2.2 生产者分区策略 2.3 经纪人(Broker)2.3.1 主题(Topic)2.3.2 分区(Partit…

人工智能与云计算实训室建设方案

一、 人工智能与云计算系统概述 人工智能(Artificial Intelligence,简称AI)是一种模拟人类智能的科学和工程,通过使用计算机系统来模拟、扩展和增强人类的智能能力。人工智能涉及多个领域,包括机器学习、深度学习、自然…

k8s简介及虚拟机快速搭建k8s集群

文章目录 1、k8s简介1.1、部署方式的变迁1.2、定义1.3、Kubernetes提供的功能 2、虚拟机快速搭建k8s集群2.1、虚拟机配置(centos7 2G内存2个处理器)2.2、基础环境准备2.3、docker安装(易踩坑)2.4、安装k8s组件2.5、master节点部署…

英飞凌在车辆信息安全方面上应用

如今,网络安全在多个层面影响着我们每个人。我们的专业工作、个人生活,甚至我们的汽车,都依赖于复杂软件上运行的连接和技术。随着信息技术日益融入我们的日常生活,我们对后续信息系统的依赖性也与日俱增。反过来,这些…