Skip to content
百科百科
操作系统
设计模式
算法
题解
java
leetcode
  • 设计模式
    • /设计模式/设计模式 - 单例.md
      • /设计模式/设计模式 - 中介者.md
        • /设计模式/设计模式 - 享元.md
          • /设计模式/设计模式 - 代理.md
            • /设计模式/设计模式 - 原型模式.md
              • /设计模式/设计模式 - 命令.md
                • /设计模式/设计模式 - 备忘录.md
                  • /设计模式/设计模式 - 外观.md
                    • /设计模式/设计模式 - 工厂方法.md
                      • /设计模式/设计模式 - 抽象工厂.md
                        • /设计模式/设计模式 - 桥接.md
                          • /设计模式/设计模式 - 模板方法.md
                            • /设计模式/设计模式 - 状态.md
                              • /设计模式/设计模式 - 生成器.md
                                • /设计模式/设计模式 - 空对象.md
                                  • /设计模式/设计模式 - 策略.md
                                    • /设计模式/设计模式 - 简单工厂.md
                                      • /设计模式/设计模式 - 组合.md
                                        • /设计模式/设计模式 - 装饰.md
                                          • /设计模式/设计模式 - 观察者.md
                                            • /设计模式/设计模式 - 解释器.md
                                              • 解释器(Interpreter)
                                                • Intent
                                                  • Class Diagram
                                                    • Implementation
                                                      • JDK
                                                    • /设计模式/设计模式 - 访问者.md
                                                      • /设计模式/设计模式 - 责任链.md
                                                        • /设计模式/设计模式 - 迭代器.md
                                                          • /设计模式/设计模式 - 适配器.md
                                                            • 一、前言
                                                              • 一、概述
                                                                • 设计模式目录

                                                                  2022年5月21日大约 1 分钟

                                                                  此页内容
                                                                  • 解释器(Interpreter)
                                                                    • Intent
                                                                    • Class Diagram
                                                                    • Implementation
                                                                    • JDK

                                                                  # 解释器(Interpreter)

                                                                  # Intent

                                                                  为语言创建解释器,通常由语言的语法和语法分析来定义。

                                                                  # Class Diagram

                                                                  • TerminalExpression:终结符表达式,每个终结符都需要一个 TerminalExpression。
                                                                  • Context:上下文,包含解释器之外的一些全局信息。

                                                                  img

                                                                  # Implementation

                                                                  以下是一个规则检验器实现,具有 and 和 or 规则,通过规则可以构建一颗解析树,用来检验一个文本是否满足解析树定义的规则。

                                                                  例如一颗解析树为 D And (A Or (B C)),文本 "D A" 满足该解析树定义的规则。

                                                                  这里的 Context 指的是 String。

                                                                  public abstract class Expression {
                                                                      public abstract boolean interpret(String str);
                                                                  }
                                                                  
                                                                  public class TerminalExpression extends Expression {
                                                                  
                                                                      private String literal = null;
                                                                  
                                                                      public TerminalExpression(String str) {
                                                                          literal = str;
                                                                      }
                                                                  
                                                                      public boolean interpret(String str) {
                                                                          StringTokenizer st = new StringTokenizer(str);
                                                                          while (st.hasMoreTokens()) {
                                                                              String test = st.nextToken();
                                                                              if (test.equals(literal)) {
                                                                                  return true;
                                                                              }
                                                                          }
                                                                          return false;
                                                                      }
                                                                  }
                                                                  
                                                                  public class AndExpression extends Expression {
                                                                  
                                                                      private Expression expression1 = null;
                                                                      private Expression expression2 = null;
                                                                  
                                                                      public AndExpression(Expression expression1, Expression expression2) {
                                                                          this.expression1 = expression1;
                                                                          this.expression2 = expression2;
                                                                      }
                                                                  
                                                                      public boolean interpret(String str) {
                                                                          return expression1.interpret(str) && expression2.interpret(str);
                                                                      }
                                                                  }
                                                                  
                                                                  public class OrExpression extends Expression {
                                                                      private Expression expression1 = null;
                                                                      private Expression expression2 = null;
                                                                  
                                                                      public OrExpression(Expression expression1, Expression expression2) {
                                                                          this.expression1 = expression1;
                                                                          this.expression2 = expression2;
                                                                      }
                                                                  
                                                                      public boolean interpret(String str) {
                                                                          return expression1.interpret(str) || expression2.interpret(str);
                                                                      }
                                                                  }
                                                                  
                                                                  public class Client {
                                                                  
                                                                      /**
                                                                       * 构建解析树
                                                                       */
                                                                      public static Expression buildInterpreterTree() {
                                                                          // Literal
                                                                          Expression terminal1 = new TerminalExpression("A");
                                                                          Expression terminal2 = new TerminalExpression("B");
                                                                          Expression terminal3 = new TerminalExpression("C");
                                                                          Expression terminal4 = new TerminalExpression("D");
                                                                          // B C
                                                                          Expression alternation1 = new OrExpression(terminal2, terminal3);
                                                                          // A Or (B C)
                                                                          Expression alternation2 = new OrExpression(terminal1, alternation1);
                                                                          // D And (A Or (B C))
                                                                          return new AndExpression(terminal4, alternation2);
                                                                      }
                                                                  
                                                                      public static void main(String[] args) {
                                                                          Expression define = buildInterpreterTree();
                                                                          String context1 = "D A";
                                                                          String context2 = "A B";
                                                                          System.out.println(define.interpret(context1));
                                                                          System.out.println(define.interpret(context2));
                                                                      }
                                                                  }
                                                                  
                                                                  true
                                                                  false
                                                                  

                                                                  # JDK

                                                                  • java.util.Patternopen in new window
                                                                  • java.text.Normalizeropen in new window
                                                                  • All subclasses of java.text.Formatopen in new window
                                                                  • javax.el.ELResolveropen in new window
                                                                  编辑此页open in new window
                                                                  上次编辑于: 2022/5/21 13:08:59
                                                                  贡献者: yzqdev
                                                                  上一页
                                                                  /设计模式/设计模式 - 观察者.md
                                                                  下一页
                                                                  /设计模式/设计模式 - 访问者.md
                                                                  powered by vuepress-theme-home