zoukankan      html  css  js  c++  java
  • 解释器模式(行为模式)

                 设计模式之Interpreter - 解释器模式             2008-06-24 10:41:46          

    分类: 项目管理

     源地址:http://blog.chinaunix.net/uid-20384806-id-1954236.html

    Interpreter模式也叫解释器模式,是由GoF提出的23种设计模式中的一种。Interpreter是行为模式之一,它是一种特殊的设计模式,它建立一个解释器,对于特定的计算机程序设计语言,用来解释预先定义的文法。

    本文介绍设计模式中的解释器(Interpreter)模式的概念,用法,以及实际应用中怎么样使用Interpreter模式进行开发。
    Interpreter模式的概念
    Interpreter是一种特殊的设计模式,它建立一个解释器,对于特定的计算机程序设计语言,用来解释预先定义的文法。简单地说,Interpreter模式是一种简单的语法解释器构架。
    Interpreter模式有很多种实现方法,下面我们给出Interpreter模式的一种类图来说明Interpreter模式:
    在上图中,我们假设需要在Client中解释某文法,Client调用Context来存储文法规则,并调用解释器AbstractionExpression类树来对该文法加以解释。注意,上图只是Interpreter模式的一种实现方式的类图。
    Context     解释器上下文环境类。用来存储解释器的上下文环境,比如需要解释的文法等。 AbstractExpression     解释器抽象类。 ConcreteExpression     解释器具体实现类。
    Interpreter模式的实现范例
    为了帮助大家理解Interpreter模式的基本概念,我们在这里只举一个最简单的例子。 让一个表达式a经过PlusExpression解释器处理后使该表达式+1,经过MinusExpression解释器处理后使该表达式-1。
    代码:
    import java.util.ArrayList; import java.util.List;
    public class Client {     public static void main(String []args) {         String inputExpr = "10";                  Context context = new Context(inputExpr);                  List list = new ArrayList();
            list.add(new PlusExpression());         list.add(new PlusExpression());         list.add(new MinusExpression());         list.add(new MinusExpression());         list.add(new MinusExpression());
            for (int i=0;i<list.size();i++) {           AbstractExpression expression = (AbstractExpression)list.get(i);           expression.interpret(context);         }                  System.out.println(context.getOutput());     } }
    /** * Context * */ class Context {     private String input;     private int output;
        public Context (String input) {         this. input = input;     }
        public String getInput() {         return input;     }
        public void setInput(String input) {         this.input = input;     }
        public int getOutput() {         return output;     }
        public void setOutput(int output) {         this.output = output;     } }
    /** * Expression & subclass * */ abstract class AbstractExpression {     public abstract void interpret(Context context); }
    class PlusExpression extends AbstractExpression {     public void interpret(Context context) {         System.out.println("PlusExpression ++");         String input = context.getInput();         int parsedResult = Integer.parseInt(input);         parsedResult ++;         context.setInput(String.valueOf(parsedResult));         context.setOutput(parsedResult);     } }
    class MinusExpression extends AbstractExpression {     public void interpret(Context context) {         System.out.println("PlusExpression --");         String input = context.getInput();         int parsedResult = Integer.parseInt(input);         parsedResult --;         context.setInput(String.valueOf(parsedResult));         context.setOutput(parsedResult);     } }
    运行并显示Client:
    C:Interpreter>javac *.java C:Interpreter>java Client PlusExpression ++ PlusExpression ++ PlusExpression -- PlusExpression -- PlusExpression -- 9 C:Interpreter>
  • 相关阅读:
    2021/9/23(桶排序+基数排序 结束排序)
    【转】十大经典排序算法(动画演示)
    如何测试代码执行时间
    图解排序算法之归并排序(转)
    TED演讲:拖延症人群的内心世界
    IntelliJ IDEA入门
    支付宝支付入门
    Spring Cloud 入门
    软件设计模式类型介绍
    《小狗钱钱2》读书笔记
  • 原文地址:https://www.cnblogs.com/kexb/p/3673533.html
Copyright © 2011-2022 走看看