设计模式 - 解释器模式

本文摘自书籍《设计模式》
此系列文章GitHub地址

行为型 - 解释器模式(Interpreter Pattern)

定义

定义语言的文法,并且建立一个解释器来解释该语言中的句子,这里语言指的是使用规定格式和语法的代码,解释模式是一种类行为型模式。

模式结构

public class Context {...}

public abstract AbstractExpression {
    void interpret(Context ctx);
}

public class TerminalExpression extends AbstractExpression {
    public void interpret(Context ctx) {
        //终结符解释操作
    }
}

public class NonterminalExpression extends AbstractExpression {
    public void interpret(Cpntext ctx) {
        //非终结符解释操作
    }
}
  • Context

    环境类,又称为上下文类,用于存储解释器之外的一些全局信息,通常它临时存储了需要解释的语句。

  • AbstractExpression

    抽象表达式,声明了抽象的解释操作,它是所有的终结符表达式和非终结符表达式的公共父类。

  • TerminalExpression

    终结符表达式,是抽象表达式的子类,实现了与文法中的终结符相关联的解释操作。在句子中的每一个终结符都是该类的一个实例。

  • NonterminalExpression

    非终结符表达式,是抽象表达式的子类,实现了文法中非终结符的解释操作,由于其中一半包含终结符表达式,也可以继续包含非终结符表达式,因此其解释操作一般通过递归的方式来完成。

优点

解释器模式的优点:

  • 易于改变和扩展文法。
  • 易于实现文法。
  • 增加了新的解释表达式的方式。

缺点

解释器模式的缺点:

  • 对于复杂文法难以维护,在解释器模式中,每一条规则至少需要定义一个类。
  • 执行效率低。
  • 应用场景有限。

应用

  • Smalltalk语言的编译器。
  • 使用解释器你模式,可以开发简单的编译器,如数学表达式解析器、正则表达式解析器。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值