命令模式
将一个请求封装为一个对象,从而使你可以用不同的请求对客户进行参数化,对请求排队和记录请求日志,以及支持可撤销的操作。
package com.ruishenh.designPatter.action.command;
public class CommandClient {
public static void main(String[] args) {
Lead lead=new Lead();
Staff staff=new Staff();
ConcreteCommand command =new ConcreteCommand(staff);
lead.setCommand(command);
lead.action();
//这一块来看的话,比如一些细节操作可能还需要变动暂时无法定下来,可以留着接口的回调函数最后来写。
lead.setCommand(new ICommand() {
@Override
public void execute() {
System.out.println("员工-有意见了,决定不干了。");
}
});
lead.action();
}
}
interface ICommand{
public void execute();
}
class ConcreteCommand implements ICommand{
Staff staff;
public ConcreteCommand(Staff staff){
this.staff = staff;
}
@Override
public void execute() {
staff.doSomething();
}
}
//命令发起者
class Lead{
private ICommand command;
public void setCommand(ICommand command) {
this.command = command;
}
public void action(){
this.command.execute();
}
}
//命令操作者
class Staff {
public void doSomething() {
System.out.println("员工-干活");
}
}
命令模式的核心任务把执行命令封装成一个对象传送给发送命令者,命令者直接执行操作。某种意义上解决了行为的操作和发起之间的解耦。
在编码上边有时候感觉就是把一些命令或者是未知的命令留着开放下来,然后在后续去完成。
状态模式
允许对象在其内部状态改变时改变他的行为。对象看起来似乎改变了他的类。
package com.ruishenh.designPatter.action.state;
public class StateClient {
public static void main(String[] args) {
Washer washer =new Washer();
washer.setState(new PowerWashState());
washer.action(null);
//切换状态
washer.setState(new StartingWashState());
washer.action(null);
}
}
interface WashState{
void Handler(String clothes);
}
class PowerWashState implements WashState{
public void Handler(String clothes) {
System.out.println("洗衣机电源打开");
}
}
class StartingWashState implements WashState{
public void Handler(String clothes) {
System.out.println("洗衣机启动洗衣服");
}
}
class WaterInWashState implements WashState{
public void Handler(String clothes) {
System.out.println("洗衣机注水中...");
}
}
class WashingWashState implements WashState{
public void Handler(String clothes) {
System.out.println("洗衣机洗衣中...");
}
}
class WaterOutWashState implements WashState{
public void Handler(String clothes) {
System.out.println("洗衣机放水中...");
}
}
class DehydrationWashState implements WashState{
public void Handler(String clothes) {
System.out.println("洗衣机脱水中...");
}
}
class ClosedWashState implements WashState{
public void Handler(String clothes) {
System.out.println("洗衣机洗衣完毕..提示.");
}
}
//洗衣机
class Washer{
WashState state;
public void setState(WashState state) {
this.state = state;
}
void action(String p1){
state.Handler(p1);
}
}
状态模式的核心就是通过一个状态的改变,而随时改变对应的状态行为。个人理解对于扩展较多且每个状态处理的逻辑可能比较复杂的时候可以选择使用此模式。否则,可能会产生很对的状态子类。维护性变的复杂
策略模式
定义一系列的算法,把他们一个个封装起来,并使他们可以互相替换,本模式使得算法可以独立于使用它们的客户。
package com.ruishenh.designPatter.action.strategy;
import java.math.BigDecimal;
public class StrategyClient {
public static void main(String[] args) {
DiscountContext context =new DiscountContext(null);
System.out.println("小明买了一件衣服原价:100元");
System.out.println("现价:"+context.getDiscountPrice(100));
System.out.println("由于小明是会员打九五折,所以");
context.setStrategy(new VipDiscount(0.95));
System.out.println("现价:"+context.getDiscountPrice(100));
System.out.println("由于小明是又买了一件衣服不能用会员,但是却参加了满100-20的活动所以");
context.setStrategy(new FullLessDiscount(100,20));
System.out.println("现价:"+context.getDiscountPrice(122));
}
}
interface DiscountStrategy{
BigDecimal getDiscount(BigDecimal price);
}
//会员
class VipDiscount implements DiscountStrategy{
public VipDiscount(double base) {
this.base=base;
}
//会员的基数
private double base;
public BigDecimal getDiscount(BigDecimal price) {
return price.multiply(new BigDecimal(base));
}
}
//满减
class FullLessDiscount implements DiscountStrategy{
public FullLessDiscount(double full,double less) {
this.full=full;
this.less=less;
}
//会员的基数
private double full;
private double less;
public BigDecimal getDiscount(BigDecimal price) {
if (price.compareTo(new BigDecimal(full))<0) {
return price;
}
return price.subtract(new BigDecimal(less));
}
}
class DiscountContext{
DiscountStrategy strategy;
public DiscountContext(DiscountStrategy strategy) {
this.strategy=strategy;
}
public DiscountStrategy getStrategy() {
return strategy;
}
public void setStrategy(DiscountStrategy strategy) {
this.strategy = strategy;
}
public double getDiscountPrice(double price){
if (strategy==null) {
strategy=new VipDiscount(1);
}
return strategy.getDiscount(new BigDecimal(price)).doubleValue();
}
}
策略模式和状态模式很相似,但状态模式侧重状态方面,一般不会接受新的状态对象,即系统已经定义足够的状态
策略侧重不同的行为的改变在统一的接口下,强调多态下面行为的执行过程,处理过程,可以从用户那里接受参数,只要用户提供的策略符合接口
分享到:
相关推荐
c++设计模式-行为型模式-解释器模式;qt工程;c++简单源码; 解释器(Interpreter)模式的定义:给分析对象定义一个语言,并定义该语言的文法表示,再设计一个解析器来解释语言中的句子。也就是说,用编译语言的方式...
行为型模式(Behavioral Patterns)是设计模式的一种,关注对象行为功能上的抽象,从而提升对象在行为功能上的可拓展性,能以最少的代码变动完成功能的增减。 在设计模式中,行为型模式主要包括以下几种: 1. 迭代...
设计模式11-行为模式-责任链、命令模式 设计模式12-解释器模式 设计模式13-迭代器模式 设计模式14-中介者模式、备忘录模式 设计模式15-观察者模式、状态模式 设计模式16-策略模式、模板方法、访问者 此PPT实例便于...
设计模式通常分为三类:创建型模式(如工厂模式、抽象工厂模式、单例模式、建造者模式、原型模式),结构型模式(如适配器模式、装饰器模式、代理模式、桥接模式、组合模式、外观模式、享元模式)以及行为型模式(如...
然后,资源对23种设计模式进行了分类和总结,包括创建型模式、结构型模式和行为型模式。 创建型模式(Creational Pattern)对类的实例化过程进行了抽象,能够将软件模块中对象的创建和对象的使用分离。共有5种,...
设计模式分为三大类:创建型模式(如单例、工厂方法、抽象工厂)、结构型模式(如代理、装饰器、适配器)和行为型模式(如观察者、策略、命令)。这些模式都是在特定上下文中解决设计问题的模板,它们可以提高代码的...
设计模式通常分为三类:创建型、结构型和行为型。创建型模式关注对象的创建,结构型模式关注对象的组合,而行为型模式关注对象之间的交互。 工厂模式是创建型设计模式之一,它的主要目的是提供一个创建对象的接口,...
Java设计模式是软件工程中的一种重要思想,它总结了在解决特定问题时,程序员们反复使用的一些最佳实践和解决方案。这个资源"Java设计模式----通俗易懂版"显然是一个专门针对初学者或需要深入理解设计模式的开发者...
设计模式是软件工程中的一种最佳实践,用于解决在软件开发过程中常见的问题。这些模式是由Erich Gamma、Richard Helm、Ralph Johnson和John Vlissides四位大师,通常被称为GoF(Gang of Four),在他们的经典著作...
《新版设计模式手册 - C#设计模式(第二版)》是一部深入探讨C#编程中设计模式的权威指南,尤其适合已经有一定C#基础并希望提升软件设计能力的开发者阅读。设计模式是解决软件开发中常见问题的经验总结,是软件工程的...
设计模式分为三类:创建型模式、结构型模式和行为型模式。创建型模式关注对象的创建过程,如单例模式(Singleton)、工厂模式(Factory)和建造者模式(Builder)等,它们提供了一种灵活的方式来创建和管理对象,...
2. **设计模式分类**:设计模式通常分为三类:创建型模式(如工厂方法、抽象工厂、单例、建造者、原型)、结构型模式(如适配器、桥接、装饰、组合、代理、外观、享元)和行为型模式(如责任链、命令、解释器、迭代...
这个压缩包文件名为“23种设计模式示例源码”,暗示其中包含了解决23种经典设计模式的具体实现代码,这对于初学者或者希望深入理解设计模式的开发者来说是一份宝贵的资源。下面将对这23种设计模式进行详细解释。 1....
全书共9章,内容包括设计模式基础、创建型设计模式(共5种)、结构型设计模式(共7种)、行为型设计模式(共11种)、设计模式实验指导。每章包括教学目标、重点内容、模式的定义与特点、模式的结构与实现、模式的...
设计模式(创建型、结构型、行为型) 设计模式是软件设计中的一种重要概念,它们可以帮助开发者更好地设计和实现软件系统。根据GoF(Gang of Four)的分类,设计模式可以分为三大类:创建型、结构型和行为型。 ...
设计模式分为三大类:创建型模式、结构型模式和行为型模式。 **创建型模式**关注的是对象的创建。共有五种创建型模式: 1. **工厂方法模式**:它定义一个用于创建对象的接口,让子类决定实例化哪一个类。工厂方法...