必知的技术知识:JAVA【设计模式】命令模式

简介: 必知的技术知识:JAVA【设计模式】命令模式

命令模式


一、定义二、示例:传统编码命令模式设计UML关系图


一、定义


命令模式:将一个请求封装为一个对象,使发出请求的责任和执行请求过程分隔开。这样两者之间通过命令对象进行沟通,便于将命令对象进行储存、传递,增强。


二、示例:


模拟场景:


1、餐厅点菜,菜品分类为:?东(鲁菜)、四川(川菜)、江苏(苏菜)、?东(粤菜)、福建(闽菜)、浙江(浙菜)、湖南(湘菜)等,每个菜肴都有对//代码效果参考:http://www.jhylw.com.cn/343930567.html

应的厨师炒出来,例如湖南厨师炒湘菜,广东厨师炒粤菜。客户向店小二提出炒什么菜肴的请求,就会有对应的厨师去处理。

传统编码


通过if实现,客气请求不同的类型,炒出什么样的菜。例如类型增多,代码会变的很臃肿


package com.qf.design.behavior.command.tradition;


import com.alibaba.fastjson.JSON;


import org.slf4j.Logger;


import org.slf4j.LoggerFactory;


import java.util.HashMap;


import java.util.Map;


public class XiaoER {


private Logger logger= LoggerFactory.getLogger(XiaoER.class);


private Map map=new HashMap();


public void order(int cusine){


//传统的编码方式所有的情况都在一个方法下面


if (cusine==1){


map.put(1, "?东厨师,烹饪鲁菜,宫廷最?菜系,以孔府?味为?头");


}


if (cusine==2){


map.put(2, "江苏厨师,烹饪苏菜,宫廷第菜系,古今国宴上最受?欢迎的菜系");


}


if (cusine==3){


map.put(3, "?东厨师,烹饪鲁菜,宫廷最?菜系,以孔府?味为?头");


}


if (cusine==4){


map.put(4, "四川厨师,烹饪川菜,中国最有特?的菜系,也是?间最?菜系。");


}


}


public void placeOrder(){


logger.info("菜单{}", JSON.toJSONString(map));


}


}


测试:ApiTest


package com.qf.design.behavior.command.tradition;


public class ApiTest {


public static void main(String【】 args) {


XiaoER xiaoER=new XiaoER();


xiaoER.order(1);


xiaoER.order(2);


xiaoER.order(3);


xiaoER.order(4);


xiaoER.placeOrder();


}


}


命令模式设计


定义做菜的接口,由各个厨师具体实现


package com.qf.design.behavior.command.design.cook;


public interface ICook {


/*


做菜


*/


void cook();


}


四川厨师


package com.qf.design.behavior.command.design.cook.impl;


import com.qf.design.behavior.command.design.cook.ICook;


import com.qf.design.behavior.command.tradition.XiaoER;


import org.slf4j.Logger;


import org.slf4j.LoggerFactory;


public class SiChuangCookImpl implements ICook {


private Logger logger= LoggerFactory.getLogger(XiaoER.class);


@Override


public void cook() {


logger.info("四川厨师,烹饪川菜,中国最有特?的菜系,也是?间最?菜系。");


}


}


?东厨师


package com.qf.design.behavior.command.design.cook.impl;


import com.qf.design.behavior.command.design.cook.ICook;


import com.qf.design.behavior.command.tradition.XiaoER;


import org.slf4j.Logger;


import org.slf4j.LoggerFactory;


public class ShangDongCookImpl implements ICook {


private Logger logger= LoggerFactory.getLogger(XiaoER.class);


@Override


public void cook() {


logger.info("?东厨师,烹饪鲁菜,宫廷最?菜系,以孔府?味为?头");


}


}


江苏厨师


package com.qf.design.behavior.command.design.cook.impl;


import com.qf.design.behavior.command.design.cook.ICook;


import com.qf.design.behavior.command.tradition.XiaoER;


import org.slf4j.Logger;


import org.slf4j.LoggerFactory;


public class JiangSuCookImpl implements ICook {


private Logger logger= LoggerFactory.getLogger(XiaoER.class);


@Override


public void cook() {


logger.info("江苏厨师,烹饪苏菜,宫廷第菜系,古今国宴上最受?欢迎的菜系");


}


}


?东厨师


package com.qf.design.behavior.command.design.cook.impl;


import com.qf.design.behavior.command.design.cook.ICook;


import com.qf.design.behavior.command.tradition.XiaoER;


import org.slf4j.Logger;


import org.slf4j.LoggerFactory;


public class GuangDongCookImpl implements ICook {


private Logger logger= LoggerFactory.getLogger(XiaoER.class);


@Override


public void cook() {


logger.info("?东厨师,烹饪鲁菜,宫廷最?菜系,以孔府?味为?头");


}


}


定义每个菜肴的接口,由各个菜肴具体实现


package com.qf.design.behavior.command.design.cusine;


public interface ICusine {


void cook();


}


四川菜


package com.qf.design.behavior.command.design.cusine.impl;


import com.qf.design.behavior.command.design.cook.ICook;


import com.qf.design.behavior.command.design.cusine.ICusine;


public class SiChuangCusineImpl implements ICusine {


private ICook cook;


public SiChuangCusineImpl(ICook cook){


this.cook=cook;


}


@Override


public void cook() {


cook.cook();


}


}


山东菜


package com.qf.design.behavior.command.design.cusine.impl;


import com.qf.design.behavior.command.design.cook.ICook;


import com.qf.design.behavior.command.design.cusine.ICusine;


public class ShangDongCusineImpl implements ICusine {


private ICook cook;


public ShangDongCusineImpl(ICook cook){


this.cook=cook;


}


@Override


public void cook() {


cook.cook();


}


}


江苏菜


package com.qf.design.behavior.command.design.cusine.impl;


import com.qf.design.behavior.command.design.cook.ICook;


import com.qf.design.behavior.command.design.cusine.ICusine;


public class JiangSuCusineImpl implements ICusine {


private ICook cook;


public JiangSuCusineImpl(ICook cook){


this.cook=cook;


}


@Override


public void cook() {


cook.cook();


}


}


粤菜


package com.qf.design.behavior.command.design.cusine.impl;


import com.qf.design.behavior.command.design.cook.ICook;


import com.qf.design.behavior.command.design.cusine.ICusine;


public class GuangdongCusineImpl implements ICusine {


private ICook cook;


public GuangdongCusineImpl(ICook cook){


this.cook=cook;


}


@Override


public void cook() {


cook.cook();


}


}


店小二负责接受客人的点单信息,转发至厨师们去实现


package com.qf.design.behavior.command.design;


import com.qf.design.behavior.command.design.cusine.ICusine;


import java.util.ArrayList;


import java.util.List;


public class Xiaoer {


private List cusineList=new ArrayList();


public void order(ICusine cusine){


cusineList.add(cusine);


}


public synchronized void placeOrder(){


for (ICusine iCusine : cusineList) {


iCusine.cook();


}


cusineList.clear();


}


}


测试:ApiTest


package com.qf.design.behavior.command.design;


import com.qf.design.behavior.command.design.cook.ICook;


import com.qf.design.behavior.command.design.cook.impl.GuangDongCookImpl;


import com.qf.design.behavior.command.design.cook.impl.JiangSuCookImpl;


import com.qf.design.behavior.command.design.cook.impl.ShangDongCookImpl;


import com.qf.design.behavior.command.design.cook.impl.SiChuangCookImpl;


import com.qf.design.behavior.command.design.cusine.ICusine;


import com.qf.design.behavior.command.design.cusine.impl.GuangdongCusineImpl;


import com.qf.design.behavior.command.design.cusine.impl.JiangSuCusineImpl;


import com.qf.design.behavior.command.design.cusine.impl.ShangDongCusineImpl;


import com.qf.design.behavior.command.design.cusine.impl.SiChuangCusineImpl;


public class ApiTest {


public static void main(String【】 args) {


ICook siChuangCook = new SiChuangCookImpl();


ICook JiangSuCookCook = new JiangSuCookImpl();


ICook ShangDongCookCook = new ShangDongCookImpl();


ICook GuangDongCook = new GuangDongCookImpl();


ICusine siChuangCusine = new SiChuangCusineImpl(siChuangCook);


ICusine jiangSuCusine = new JiangSuCusineImpl(JiangSuCookCook);


ICusine guangdongCusine = new GuangdongCusineImpl(GuangDongCook);


ICusine shangDongCusine = new ShangDongCusineImpl(ShangDongCookCook);


Xiaoer xiaoer = new Xiaoer();


xiaoer.order(siChuangCusine);


xiaoer.order(jiangSuCusine);


xiaoer.order(guangdongCusine);


xiaoer.order(shangDongCusine);


xiaoer.placeOrder();


}


}


UML关系图


总结:


从以上的内容和例?可以感受到,命令模式的使?场景需要分为三个?较?的块; 命令 、 实现 、调?者 ,?这三块内容的拆分也是选择适合场景的关键因素,经过这样的拆分可以让逻辑具备单?职责的性质,便于扩展。


通过这样的实现?式与if语句相?,降低了耦合性也?便其他的命令和实现的扩展。但同时这样的设计模式也带来了?点问题,就是在各种命令与实现的组合下,会扩展出很多的实现类,需要进?管理。

相关文章
|
1月前
|
设计模式 Java Spring
Java 设计模式之责任链模式:优雅处理请求的艺术
责任链模式通过构建处理者链,使请求沿链传递直至被处理,实现发送者与接收者的解耦。适用于审批流程、日志处理等多级处理场景,提升系统灵活性与可扩展性。
212 2
|
2月前
|
监控 Cloud Native Java
Quarkus 云原生Java框架技术详解与实践指南
本文档全面介绍 Quarkus 框架的核心概念、架构特性和实践应用。作为新一代的云原生 Java 框架,Quarkus 旨在为 OpenJDK HotSpot 和 GraalVM 量身定制,显著提升 Java 在容器化环境中的运行效率。本文将深入探讨其响应式编程模型、原生编译能力、扩展机制以及与微服务架构的深度集成,帮助开发者构建高效、轻量的云原生应用。
343 44
|
1月前
|
设计模式 网络协议 数据可视化
Java 设计模式之状态模式:让对象的行为随状态优雅变化
状态模式通过封装对象的状态,使行为随状态变化而改变。以订单为例,将待支付、已支付等状态独立成类,消除冗长条件判断,提升代码可维护性与扩展性,适用于状态多、转换复杂的场景。
258 0
|
2月前
|
安全 Java API
Java Web 在线商城项目最新技术实操指南帮助开发者高效完成商城项目开发
本项目基于Spring Boot 3.2与Vue 3构建现代化在线商城,涵盖技术选型、核心功能实现、安全控制与容器化部署,助开发者掌握最新Java Web全栈开发实践。
361 1
|
3月前
|
设计模式 缓存 Java
Java设计模式(二):观察者模式与装饰器模式
本文深入讲解观察者模式与装饰器模式的核心概念及实现方式,涵盖从基础理论到实战应用的全面内容。观察者模式实现对象间松耦合通信,适用于事件通知机制;装饰器模式通过组合方式动态扩展对象功能,避免子类爆炸。文章通过Java示例展示两者在GUI、IO流、Web中间件等场景的应用,并提供常见陷阱与面试高频问题解析,助你写出灵活、可维护的代码。
|
3月前
|
安全 Java 编译器
new出来的对象,不一定在堆上?聊聊Java虚拟机的优化技术:逃逸分析
逃逸分析是一种静态程序分析技术,用于判断对象的可见性与生命周期。它帮助即时编译器优化内存使用、降低同步开销。根据对象是否逃逸出方法或线程,分析结果分为未逃逸、方法逃逸和线程逃逸三种。基于分析结果,编译器可进行同步锁消除、标量替换和栈上分配等优化,从而提升程序性能。尽管逃逸分析计算复杂度较高,但其在热点代码中的应用为Java虚拟机带来了显著的优化效果。
127 4
|
3月前
|
Java API Maven
2025 Java 零基础到实战最新技术实操全攻略与学习指南
本教程涵盖Java从零基础到实战的全流程,基于2025年最新技术栈,包括JDK 21、IntelliJ IDEA 2025.1、Spring Boot 3.x、Maven 4及Docker容器化部署,帮助开发者快速掌握现代Java开发技能。
790 1
|
1月前
|
设计模式 算法 搜索推荐
Java 设计模式之策略模式:灵活切换算法的艺术
策略模式通过封装不同算法并实现灵活切换,将算法与使用解耦。以支付为例,微信、支付宝等支付方式作为独立策略,购物车根据选择调用对应支付逻辑,提升代码可维护性与扩展性,避免冗长条件判断,符合开闭原则。
259 35
|
1月前
|
设计模式 消息中间件 传感器
Java 设计模式之观察者模式:构建松耦合的事件响应系统
观察者模式是Java中常用的行为型设计模式,用于构建松耦合的事件响应系统。当一个对象状态改变时,所有依赖它的观察者将自动收到通知并更新。该模式通过抽象耦合实现发布-订阅机制,广泛应用于GUI事件处理、消息通知、数据监控等场景,具有良好的可扩展性和维护性。
219 8
|
3月前
|
设计模式 安全 Java
Java设计模式(一):单例模式与工厂模式
本文详解单例模式与工厂模式的核心实现及应用,涵盖饿汉式、懒汉式、双重检查锁、工厂方法、抽象工厂等设计模式,并结合数据库连接池与支付系统实战案例,助你掌握设计模式精髓,提升代码专业性与可维护性。

热门文章

最新文章

下一篇
oss云网关配置