设计模式 ------- 仿写Android RxJava 中的装饰器模式

2023-12-16 01:08

本文主要是介绍设计模式 ------- 仿写Android RxJava 中的装饰器模式,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

仿写RxJava中的装饰器模式:


整个例子的背景:用户选择商品、下单、店家发货、快递、拿到商品。

交易类:Delivery

public abstract class Delivery {public abstract void transport(Product product);public void arrive(Product product){transport(product);}// 创建订单与收获地址public static Delivery create(String name,Order order){// 创建收获地址DeliveryCreate deliveryCreate=new DeliveryCreate(order);// 创建快递return new DeliveryProcess(deliveryCreate,name);}// 设置商品传递流程public Delivery sendOrderToLocation(String name){return new DeliveryProcess(this,name);}// 设置商品传递流程,且做些事public Delivery sendOrderToLocation(String name,String thing){return new DeliveryProcess(this,name,thing);}// 转换商品public Delivery map(String name,Exchange<?,?> p){return new DeliveryProcess(this,name,p);}
}

创建订单和收获地址类:

public class DeliveryCreate extends Delivery{// 订单private Order order;public DeliveryCreate(Order order){this.order = order;}// 收获地址@Overridepublic void transport(Product product) {System.out.println("用户拿到了商品");order.apply(product);}
}

订单类:Order

public interface Order {void apply(Product dothing);
}

快递传递类:DeliveryProcess

public class DeliveryProcess extends Delivery{private Exchange exchange;private String name;private String otherThing;private Delivery parent;public DeliveryProcess(Delivery nextNode, String name){System.out.println("LogOut:订单到达-----"+name);this.parent= nextNode;this.name= name;}public DeliveryProcess(Delivery nextNode,String name,Exchange exchange){System.out.println("LogOut:订单到达-----"+name);this.name=name;this.parent= nextNode;this.exchange= exchange;}public DeliveryProcess(Delivery nextNode, String name,String otherThing){System.out.println("LogOut:订单到达-----"+name);this.parent= nextNode;this.name= name;this.otherThing=otherThing;}// 传递快递@Overridepublic void transport(Product product) {if(name!=null){System.out.println("LogOut:商品已发货,目前到达-----"+name);}if(otherThing!=null){System.out.println("LogOut:商品检查:-----"+otherThing);}Product newProduct=product;if (exchange!=null){newProduct=exchange.change(product);}// 将快递给下一个快递站parent.transport(newProduct);}}

商品类:Product

public interface Product<T> {void size(int d);void number(int t);void color(String  e);void content(T info);
}

商品转换类:

public interface Exchange<R,T> {Product<T> change(Product<R> product);
}

main:

Delivery.create("用户下单地点",new Order() {@Overridepublic void apply(Product dothing) {dothing.color("Red");dothing.size(100);dothing.number(10);dothing.content("三只松鼠");}}).sendOrderToLocation("广东","检查下是否过期了").sendOrderToLocation("四川","看看好不好吃???").sendOrderToLocation("三只松鼠旗舰店").arrive(new Product<String>() {@Overridepublic void number(int d) {System.out.println("商品的个数:"+d);}@Overridepublic void size(int big) {System.out.println("商品的大小:"+big);}@Overridepublic void color(String col) {System.out.println("商品的颜色:"+col);}@Overridepublic void content(String str) {System.out.println("商品的类型:"+str);}});}

执行结果:

LogOut:订单到达-----用户下单地点
LogOut:订单到达-----广东
LogOut:订单到达-----四川
LogOut:订单到达-----三只松鼠旗舰店
LogOut:商品已发货,目前到达-----三只松鼠旗舰店
LogOut:商品已发货,目前到达-----四川
LogOut:商品检查:-----看看好不好吃???
LogOut:商品已发货,目前到达-----广东
LogOut:商品检查:-----检查下是否过期了
LogOut:商品已发货,目前到达-----用户下单地点
用户拿到了商品,三只松鼠
商品的颜色:Red
商品的大小:100
商品的个数:10
商品的类型:三只松鼠

添加商品转换:

Delivery.create("用户下单地点",new Order() {@Overridepublic void apply(Product dothing) {dothing.color("Red");dothing.size(100);dothing.number(10);dothing.content(12);}}).sendOrderToLocation("广东","检查下是否过期了").map("重庆", new Exchange<Integer, String>() {@Overridepublic Product<Integer> change(Product food) {return new Product<Integer>() {@Overridepublic void number(int d) {System.out.println("商品被掉包:number");food.number(5);}@Overridepublic void size(int big) {System.out.println("商品被掉包:size");food.size(big);}@Overridepublic void color(String cor) {System.out.println("商品被掉包:color");food.color("绿色");}@Overridepublic void content(Integer str) {System.out.println("商品被掉包:info");food.content("重庆火锅");}};}}).sendOrderToLocation("四川","看看好不好吃???").sendOrderToLocation("三只松鼠旗舰店").arrive(new Product<String>() {@Overridepublic void number(int d) {System.out.println("商品的个数:"+d);}@Overridepublic void size(int big) {System.out.println("商品的大小:"+big);}@Overridepublic void color(String col) {System.out.println("商品的颜色:"+col);}@Overridepublic void content(String str) {System.out.println("商品的类型:"+str);}});}

打印结果:

LogOut:订单到达-----用户下单地点
LogOut:订单到达-----广东
LogOut:订单到达-----重庆
LogOut:订单到达-----四川
LogOut:订单到达-----三只松鼠旗舰店
LogOut:商品已发货,目前到达-----三只松鼠旗舰店
LogOut:商品已发货,目前到达-----四川
LogOut:商品检查:-----看看好不好吃???
LogOut:商品已发货,目前到达-----重庆
LogOut:商品已发货,目前到达-----广东
LogOut:商品检查:-----检查下是否过期了
LogOut:商品已发货,目前到达-----用户下单地点
用户拿到了商品
商品被掉包:color
商品的颜色:绿色
商品被掉包:size
商品的大小:100
商品被掉包:number
商品的个数:5
商品被掉包:info
商品的类型:重庆火锅

上面的仿写,其实就做了两件事:在拿到商品前,不停的装饰自己(即添加额外操作),拿到商品后,不停的卸装(执行额外操作,然后将商品传给下一层)。

这种设计模式是一种垂直方向添加功能,上一层需要持有下一层的对象。

缺点: 多层装饰比较复杂

 

这篇关于设计模式 ------- 仿写Android RxJava 中的装饰器模式的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

Spring boot整合dubbo+zookeeper的详细过程

《Springboot整合dubbo+zookeeper的详细过程》本文讲解SpringBoot整合Dubbo与Zookeeper实现API、Provider、Consumer模式,包含依赖配置、... 目录Spring boot整合dubbo+zookeeper1.创建父工程2.父工程引入依赖3.创建ap

SpringBoot结合Docker进行容器化处理指南

《SpringBoot结合Docker进行容器化处理指南》在当今快速发展的软件工程领域,SpringBoot和Docker已经成为现代Java开发者的必备工具,本文将深入讲解如何将一个SpringBo... 目录前言一、为什么选择 Spring Bootjavascript + docker1. 快速部署与

Spring Boot spring-boot-maven-plugin 参数配置详解(最新推荐)

《SpringBootspring-boot-maven-plugin参数配置详解(最新推荐)》文章介绍了SpringBootMaven插件的5个核心目标(repackage、run、start... 目录一 spring-boot-maven-plugin 插件的5个Goals二 应用场景1 重新打包应用

SpringBoot+EasyExcel实现自定义复杂样式导入导出

《SpringBoot+EasyExcel实现自定义复杂样式导入导出》这篇文章主要为大家详细介绍了SpringBoot如何结果EasyExcel实现自定义复杂样式导入导出功能,文中的示例代码讲解详细,... 目录安装处理自定义导出复杂场景1、列不固定,动态列2、动态下拉3、自定义锁定行/列,添加密码4、合并

Spring Boot集成Druid实现数据源管理与监控的详细步骤

《SpringBoot集成Druid实现数据源管理与监控的详细步骤》本文介绍如何在SpringBoot项目中集成Druid数据库连接池,包括环境搭建、Maven依赖配置、SpringBoot配置文件... 目录1. 引言1.1 环境准备1.2 Druid介绍2. 配置Druid连接池3. 查看Druid监控

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

创建Java keystore文件的完整指南及详细步骤

《创建Javakeystore文件的完整指南及详细步骤》本文详解Java中keystore的创建与配置,涵盖私钥管理、自签名与CA证书生成、SSL/TLS应用,强调安全存储及验证机制,确保通信加密和... 目录1. 秘密键(私钥)的理解与管理私钥的定义与重要性私钥的管理策略私钥的生成与存储2. 证书的创建与

浅析Spring如何控制Bean的加载顺序

《浅析Spring如何控制Bean的加载顺序》在大多数情况下,我们不需要手动控制Bean的加载顺序,因为Spring的IoC容器足够智能,但在某些特殊场景下,这种隐式的依赖关系可能不存在,下面我们就来... 目录核心原则:依赖驱动加载手动控制 Bean 加载顺序的方法方法 1:使用@DependsOn(最直

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期