Java设计模式--解释器模式

解释器模式

给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。

Interpreter Pattern

Given a language, define a representation for its grammar along with an interpreter that uses the representation to interpret sentences in the language.

类图

模式的结构与使用

解释器模式的结构中包括四个角色。
+ 抽象表达式(AbstractExpression):该角色为一个接口,负责定义抽象的解释操作。
+ 终结符表达式(TerminalExpression):实现AbstractExpression接口的类。该类将接口中的解释器操作实现为与文法中的终结符相关联的操作,即文法中的每个终结符需要一个TerminalExpression类。
+ 非终结符表达式(NonterminalExpression):实现AbstractExpression接口的类。文法中的每一条规则R::=R1R2…Rn都需要一个NonterminalExpression类。NonterminalExpression类为文法中的非终结符号实现解释操作,该解释操作通常使用递归用表示Ri到Rn的那些对象的解释操作。
+ 上下文(Context):包含解释器之外的一些全局信息。

简单的例子

Node的接口类Dog.java

package Interpreter;

public interface Node {
    public void parse(Context text);
    public void execute();
}

Context的类Context.java

package Interpreter;

import java.util.StringTokenizer;

public class Context {
    StringTokenizer tokenizer;
    String token;

    public Context(String text) {
        setContext(text);
    }

    public void setContext(String text) {
        tokenizer = new StringTokenizer(text);
    }

    String nextToken() {
        if (tokenizer.hasMoreTokens()) {
            token = tokenizer.nextToken();
        } else
            token = "";
        return token;
    }
}

Node的实现类SubjectPronounOrNounNode.java

package Interpreter;

public class SubjectPronounOrNounNode implements Node {

    String[] word = {"You", "He", "Teacher", "Student"};
    String token;
    boolean boo;

    @Override
    public void parse(Context context) {
        token = context.nextToken();
        int i = 0;
        for (; i < word.length; i++) {
            if (token.equalsIgnoreCase(word[i])) {
                boo = true;
                break;
            }
        }
        if (i == word.length) {
            boo = false;
        }
    }

    @Override
    public void execute() {
        if (boo) {
            if (token.equalsIgnoreCase(word[0]))
                System.out.print("你");
            if (token.equalsIgnoreCase(word[1]))
                System.out.print("他");
            if (token.equalsIgnoreCase(word[2]))
                System.out.print("老师");
            if (token.equalsIgnoreCase(word[3]))
                System.out.print("学生");
        } else {
            System.out.println(token + "(不是该语言中的语句)");
        }
    }
}

Node的实现类ObjectPronounOrNounNode.java

package Interpreter;

public class ObjectPronounOrNounNode implements Node {

    String[] word = {"Me", "Him", "Tiger", "Apple"};
    String token;
    boolean boo;

    @Override
    public void parse(Context context) {
        token = context.nextToken();
        int i = 0;
        for (; i < word.length; i++) {
            if (token.equalsIgnoreCase(word[i])) {
                boo = true;
                break;
            }
        }
        if (i == word.length) {
            boo = false;
        }
    }

    @Override
    public void execute() {
        if (boo) {
            if (token.equalsIgnoreCase(word[0]))
                System.out.print("我");
            if (token.equalsIgnoreCase(word[1]))
                System.out.print("他");
            if (token.equalsIgnoreCase(word[2]))
                System.out.print("老虎");
            if (token.equalsIgnoreCase(word[3]))
                System.out.print("苹果");
        } else {
            System.out.println(token + "(不是该语言中的语句)");
        }
    }
}

Node的实现类VerbNode.java

package Interpreter;

public class VerbNode implements Node {

    String[] word = {"Drink", "Eat", "Look", "beat"};
    String token;
    boolean boo;

    @Override
    public void parse(Context context) {
        token = context.nextToken();
        int i = 0;
        for (; i < word.length; i++) {
            if (token.equalsIgnoreCase(word[i])) {
                boo = true;
                break;
            }
        }
        if (i == word.length) {
            boo = false;
        }
    }

    @Override
    public void execute() {
        if (boo) {
            if (token.equalsIgnoreCase(word[0]))
                System.out.print("喝");
            if (token.equalsIgnoreCase(word[1]))
                System.out.print("吃");
            if (token.equalsIgnoreCase(word[2]))
                System.out.print("看");
            if (token.equalsIgnoreCase(word[3]))
                System.out.print("打");
        } else {
            System.out.println(token + "(不是该语言中的语句)");
        }
    }
}

Node的实现类SubjectNode.java

package Interpreter;

public class SubjectNode implements Node {

    Node node;

    @Override
    public void parse(Context text) {
        node = new SubjectPronounOrNounNode();
        node.parse(text);
    }

    @Override
    public void execute() {
        node.execute();
    }
}

Node的实现类PredicateNode.java

papackage Interpreter;

public class PredicateNode implements Node {

    Node verbNode, objectNode;

    @Override
    public void parse(Context text) {
        verbNode = new VerbNode();
        objectNode = new ObjectPronounOrNounNode();
        verbNode.parse(text);
        objectNode.parse(text);
    }

    @Override
    public void execute() {
        verbNode.execute();
        objectNode.execute();
    }
}

Node的实现类SentenceNode.java

package Interpreter;

public class SentenceNode implements Node {

    Node subjectNode, predicateNode;

    @Override
    public void parse(Context text) {
        subjectNode = new SubjectNode();
        predicateNode = new PredicateNode();
        subjectNode.parse(text);
        predicateNode.parse(text);
    }

    @Override
    public void execute() {
        subjectNode.execute();
        predicateNode.execute();
    }
}

测试类Application.java

package Interpreter;

public class Application {

    public static void main(String[] args) {
        String text = "Teacher beat tiger";
        Context context = new Context(text);
        Node node = new SentenceNode();
        node.parse(context);
        node.execute();
        System.out.println();
        text = "You eat apple";
        context.setContext(text);
        node.parse(context);
        node.execute();
    }
}

运行结果

老师打老虎
你吃苹果

解释器模式的优点

  • 将每一个语法规则表示成一个类,方便于实现简单的语言。
  • 由于使用类表示语法规则,可以较容易改变或扩展语言的行为。
  • 通过在类结构中加入新的方法,可以在解释的同时增加新的行为。

适用解释器模式的情景

  • 当有一个简单的语言需要解释执行,并且可以将该语言的每一个规则表示为一个类时,就可以使用解释模式。

注意:如果文法过于复杂,那么过多的文法规则使我们很艰难维护所给出的类。

下载源码请到

MyGitHub

时间: 2024-09-19 09:49:48

Java设计模式--解释器模式的相关文章

PHP设计模式——解释器模式

声明:本系列博客参考资料<大话设计模式>,作者程杰.         解释器模式:Given a language, define arepresentation for its grammar along with an interpreter that uses therepresentation to interpret sentences in the language.给定一个语言, 定义它的文法的一种表示,并定义一个解释器,该解释器使用该表示来解释语言中的句子.        类图

20、Python与设计模式--解释器模式

一.模拟吉他 要开发一个自动识别谱子的吉他模拟器,达到录入谱即可按照谱发声的效果.除了发声设备外(假设已完成),最重要的就是读谱和译谱能力了.分析其需求,整个过程大致上分可以分为两部分:根据规则翻译谱的内容:根据翻译的内容演奏.我们用一个解释器模型来完成这个功能. class PlayContext(): play_text = None class Expression(): def interpret(self, context): if len(context.play_text) ==

Java设计模式---Builder模式

之前想多写一些关于设计模式之类的东西,但是一直没写,主要是现在网上写这些的太多了,都懒的弄,反正我写这篇是写给自己做笔记的,我自己看,哼. 设计模式真的太重要了,不论是以后转学哪门语言,面向对象思想在这了,架构搭起来就会清晰些. 动手: 以前我们给model赋值的时候是这个样子的 Person person=new Person(); person.setAge(13); person.setId("33"); person.setName("薛之谦"); 这个是我

java设计模式-桥接模式(屌丝男学设计模式)

本文介绍设计模式中的桥接(Bridge)模式的概念,用法,以及实际应用中怎么样使用桥接模式进行开发. Bridge模式的概念 Bridge 模式是构造型的设计模式之一.Bridge模式基于类的最小设计原则,通过使用封装,聚合以及继承等行为来让不同的类承担不同的责任.它的主要特点是把抽象(abstraction)与行为实现(implementation)分离开来,从而可以保持各部分的独立性以及应对它们的功能扩展. Bridge模式的应用场景 面向对象的程序设计(OOP)里有类继承(子类继承父类)的

Java设计模式--备忘录模式

备忘录模式(别名:标记) 在不破坏封装性的前提下,捕捉一个对象的内部状态,并在该对象之外保存这个状态,这样以后就可将该对象恢复到原先保存的状态. Memento Pattern(Another Name: Token) Without violating encapsulation, capture and externalize an object original state so that the object can be restored to this state later. 类图

Java设计模式--模板方法模式

模板方法模式 定义一个操作中算法的骨架,而将一些步骤延迟到子类中.模板方法使子类可以不改变一个算法的结构即可重定义该算法的某些特定步骤. Template Method Pattern Define the skeleton of an algorithm in an operation, deferring some steps to subclasses. Template Method lets subclasses redefine certain steps of an algorit

Java设计模式--外观模式

外观模式 为系统中的一组接口提供一个一致的界面,Facade模式定义了一个高层接口,这个接口使得这一子系统更加容易使用. Facade Pattern Provide a unified interface to a set of interfaces in a subsystem. Facade defines a higher-level interface that makes the subsystem easier to use. 类图 模式的结构与使用 外观模式的结构中包两种角色.

Java设计模式--桥接模式

桥接模式(别名:柄体模式) 将抽象部分于它的实现部分分离,使它们都可以独立地变化. Bridge Pattern(Another Name:Handle-Body) Decouple an abstraction from its implementation so that the two can vary independently. 类图 模式的结构与使用 桥接模式的结构中包括四种角色. + 抽象(Abstraction):是一个抽象类,该抽象类含有Implementor声明的变量,即维护

Java设计模式--组合模式

组合模式 将对象组合成树形结构以表示"部分-整体"的层次结构.Composite使用户对单个对象和组合对象的使用具有一致性. Composite Pattern Compose objects into tree structures to represent part-whole hierarchies. Composite lets clients treat individual objects and compositions of objects uniformly. 类图