设计模式(022)行为型之解释器模式

        解释器模式是一种行为型设计模式,用于定义一种语言的文法,并且在该语言中解释句子的意义。这种模式通常用于实现编程语言解释器、正则表达式引擎等场景。
在解释器模式中,主要有以下几个角色:
① 抽象表达式(AbstractExpression):定义了解释器的接口,包含一个 `interpret` 方法用于解释句子。
② 终结符表达式(TerminalExpression):实现了抽象表达式接口,代表文法中的终结符,比如变量或者常量。
③ 非终结符表达式(NonterminalExpression):实现了抽象表达式接口,代表文法中的非终结符,通常是由终结符表达式组成的组合。
④ 上下文环境(Context):包含了解释器解释的上下文信息,可能影响解释的结果。
⑤ 客户端(Client):构建待解释的语句,并将其传递给解释器进行解释。
解释器模式通过组合表达式来解释句子,将复杂的语法规则分解成简单的表达式,然后递归地解释每个表达式,最终得到结果。

1、场景设计

实现场景:使用解释器模式模拟一个简单的布尔表达式。

2、C++实现

模拟了一个简单的布尔表达式解释器。`Context` 类表示上下文环境,存储了变量的值。`Expression` 是抽象表达式类,定义了解释器的接口。`TerminalExpression` 是终结符表达式类,表示单个变量的值。`OrExpression` 是非终结符表达式类,表示两个表达式的逻辑或操作。在 `main` 函数中,我们设置了变量 A 和 B 的值,并构建了一个逻辑或表达式,最后对该表达式进行解释。 

#include <iostream>
#include <unordered_map>
#include <string>

// 上下文环境类
class Context {
    private:
        std::unordered_map<std::string, bool> variables;

    public:
        void setVariable(const std::string& name, bool value) {
            variables[name] = value;
        }

        bool getVariable(const std::string& name) {
            return variables[name];
        }
};

// 抽象表达式类
class Expression {
    public:
        virtual bool interpret(Context& context) = 0;
};

// 终结符表达式类
class TerminalExpression : public Expression {
    private:
        std::string variable;

    public:
        TerminalExpression(const std::string& variable) : variable(variable) {}

        bool interpret(Context& context) override {
            return context.getVariable(variable);
        }
};

// 非终结符表达式类
class OrExpression : public Expression {
    private:
        Expression* expression1;
        Expression* expression2;

    public:
        OrExpression(Expression* expr1, Expression* expr2) : expression1(expr1), expression2(expr2) {}

        bool interpret(Context& context) override {
            return expression1->interpret(context) || expression2->interpret(context);
        }

        ~OrExpression() {
            delete expression1;
            delete expression2;
        }
};

// 客户端代码
int main() {
    Context context;
    context.setVariable("A", true);
    context.setVariable("B", false);

    Expression* expression = new OrExpression(new TerminalExpression("A"), new TerminalExpression("B"));

    std::cout << "A OR B is: " << expression->interpret(context) << std::endl;

    delete expression;

    return 0;
}

3、Java实现

模拟了一个简单的布尔表达式解释器。`Context` 类表示上下文环境,存储了变量的值。`Expression` 是抽象表达式接口,定义了解释器的方法。`TerminalExpression` 是终结符表达式类,表示单个变量的值。`OrExpression` 是非终结符表达式类,表示两个表达式的逻辑或操作。在 `main` 方法中,我们设置了变量 A 和 B 的值,并构建了一个逻辑或表达式,最后对该表达式进行解释。 

package behavioralpattern.interpreter;

import java.util.HashMap;
import java.util.Map;

// 上下文环境类
class Context {
    private Map<String, Boolean> variables = new HashMap<>();

    public void setVariable(String name, boolean value) {
        variables.put(name, value);
    }

    public boolean getVariable(String name) {
        return variables.getOrDefault(name, false);
    }
}

// 抽象表达式类
interface Expression {
    boolean interpret(Context context);
}

// 终结符表达式类
class TerminalExpression implements Expression {
    private String variable;

    public TerminalExpression(String variable) {
        this.variable = variable;
    }

    @Override
    public boolean interpret(Context context) {
        return context.getVariable(variable);
    }
}

// 非终结符表达式类
class OrExpression implements Expression {
    private Expression expression1;
    private Expression expression2;

    public OrExpression(Expression expression1, Expression expression2) {
        this.expression1 = expression1;
        this.expression2 = expression2;
    }

    @Override
    public boolean interpret(Context context) {
        return expression1.interpret(context) || expression2.interpret(context);
    }
}

public class InterpreterDemo {
    public static void main(String[] args) {
        Context context = new Context();
        context.setVariable("A", true);
        context.setVariable("B", false);

        Expression expression = new OrExpression(new TerminalExpression("A"), new TerminalExpression("B"));

        System.out.println("A OR B is: " + expression.interpret(context));
    }
}

相关推荐

  1. 设计模式(022)行为解释模式

    2024-04-21 05:20:02       34 阅读
  2. 设计模式行为设计模式——解释模式

    2024-04-21 05:20:02       40 阅读
  3. 设计模式行为模式解释模式

    2024-04-21 05:20:02       43 阅读
  4. GO设计模式——17、解释模式行为

    2024-04-21 05:20:02       61 阅读
  5. 设计模式(014)行为迭代模式

    2024-04-21 05:20:02       31 阅读
  6. 设计模式(023)行为中介者模式

    2024-04-21 05:20:02       26 阅读
  7. 设计模式(021)行为访问者模式

    2024-04-21 05:20:02       37 阅读
  8. 设计模式(020)行为备忘录模式

    2024-04-21 05:20:02       43 阅读
  9. 设计模式行为设计模式 模板方法模式

    2024-04-21 05:20:02       38 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-04-21 05:20:02       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-04-21 05:20:02       100 阅读
  3. 在Django里面运行非项目文件

    2024-04-21 05:20:02       82 阅读
  4. Python语言-面向对象

    2024-04-21 05:20:02       91 阅读

热门阅读

  1. 【QT教程】QT6单元测试

    2024-04-21 05:20:02       39 阅读
  2. 16篇 hdfs中篇

    2024-04-21 05:20:02       154 阅读
  3. linux nohup命令启动jar包 如何取消nohup日志打印

    2024-04-21 05:20:02       46 阅读
  4. C语言实现单链表

    2024-04-21 05:20:02       39 阅读
  5. XiaodiSec day011 Learn Note 小迪渗透学习笔记

    2024-04-21 05:20:02       37 阅读
  6. ChatGPT引领:打造独具魅力的论文

    2024-04-21 05:20:02       45 阅读
  7. MySQL怎么排查慢sql语句,排查后一般怎么优化

    2024-04-21 05:20:02       36 阅读