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

简介: 解释器模式给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。Interpreter PatternGiven a language, define a representation for its grammar along with an interpreter that uses the representat

解释器模式

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

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

目录
相关文章
|
5月前
|
设计模式 网络协议 数据可视化
Java 设计模式之状态模式:让对象的行为随状态优雅变化
状态模式通过封装对象的状态,使行为随状态变化而改变。以订单为例,将待支付、已支付等状态独立成类,消除冗长条件判断,提升代码可维护性与扩展性,适用于状态多、转换复杂的场景。
771 157
|
5月前
|
设计模式 Java Spring
Java 设计模式之责任链模式:优雅处理请求的艺术
责任链模式通过构建处理者链,使请求沿链传递直至被处理,实现发送者与接收者的解耦。适用于审批流程、日志处理等多级处理场景,提升系统灵活性与可扩展性。
621 2
|
7月前
|
设计模式 缓存 Java
Java设计模式(二):观察者模式与装饰器模式
本文深入讲解观察者模式与装饰器模式的核心概念及实现方式,涵盖从基础理论到实战应用的全面内容。观察者模式实现对象间松耦合通信,适用于事件通知机制;装饰器模式通过组合方式动态扩展对象功能,避免子类爆炸。文章通过Java示例展示两者在GUI、IO流、Web中间件等场景的应用,并提供常见陷阱与面试高频问题解析,助你写出灵活、可维护的代码。
|
5月前
|
设计模式 算法 搜索推荐
Java 设计模式之策略模式:灵活切换算法的艺术
策略模式通过封装不同算法并实现灵活切换,将算法与使用解耦。以支付为例,微信、支付宝等支付方式作为独立策略,购物车根据选择调用对应支付逻辑,提升代码可维护性与扩展性,避免冗长条件判断,符合开闭原则。
1114 35
|
5月前
|
设计模式 消息中间件 传感器
Java 设计模式之观察者模式:构建松耦合的事件响应系统
观察者模式是Java中常用的行为型设计模式,用于构建松耦合的事件响应系统。当一个对象状态改变时,所有依赖它的观察者将自动收到通知并更新。该模式通过抽象耦合实现发布-订阅机制,广泛应用于GUI事件处理、消息通知、数据监控等场景,具有良好的可扩展性和维护性。
471 8
|
10月前
|
设计模式 缓存 安全
【高薪程序员必看】万字长文拆解Java并发编程!(8):设计模式-享元模式设计指南
🌟 ​大家好,我是摘星!​ 🌟今天为大家带来的是并发编程中的经典对象复用设计模式-享元模式,废话不多说让我们直接开始。
217 0
|
7月前
|
设计模式 安全 Java
Java设计模式(一):单例模式与工厂模式
本文详解单例模式与工厂模式的核心实现及应用,涵盖饿汉式、懒汉式、双重检查锁、工厂方法、抽象工厂等设计模式,并结合数据库连接池与支付系统实战案例,助你掌握设计模式精髓,提升代码专业性与可维护性。
|
7月前
|
设计模式 XML 安全
Java枚举(Enum)与设计模式应用
Java枚举不仅是类型安全的常量,还具备面向对象能力,可添加属性与方法,实现接口。通过枚举能优雅实现单例、策略、状态等设计模式,具备线程安全、序列化安全等特性,是编写高效、安全代码的利器。
|
10月前
|
设计模式 Java 编译器
【设计模式】【行为型模式】解释器模式(Interpreter)
一、入门 什么是解释器模式? 解释器模式(Interpreter Pattern)是一种行为设计模式,用于定义语言的语法表示,并提供一个解释器来处理该语法。它通常用于需要解释和执行特定语言或表达式的场
233 11
|
设计模式 SQL Java
【再谈设计模式】解释器模式~语法的解析执行者
解释器模式定义了一种语言的语法表示,并定义一个解释器来解释该语言中的句子。它使用类来表示每个语法规则,并且通过递归调用这些类的方法来解释表达式。本质上,它将一个复杂的表达式分解为一系列简单的部分,然后按照特定的语法规则进行解析和执行。
328 8