当前位置: 首页 > news >正文

《golang设计模式》第三部分·行为型模式-03-解释器模式(Interpreter)

文章目录

  • 1. 概述
    • 1.1 角色
    • 1.2 类图
    • 1.3 优缺点
  • 2. 代码示例
    • 2.1 设计
    • 2.2 代码
    • 2.3 类图

1. 概述

解释器模式(Interpreter)是用于表达语言语法树和封装语句解释(或运算)行为的对象。

1.1 角色

  • AbstractExpression(抽象表达式):具体表达式的一个抽象接口,交由具体子类进行具体解释
  • TerminalExpression(终结符表达式):实现文法中与终结符有关的解释操作
  • NonTerminalExpression(非终结符表达式):实现文法中与非终结符有关的解释操作
  • Context(上下文环境类):解释器上下文环境类
  • Client :持有上下文和抽象表达式,

1.2 类图

Context
AbstractExpression
TerminalExpression
+Interpret(con:Context)
NoTerminalExpression
+Interpret(con:Context)
Client

1.3 优缺点

  • 优点
    • 可拓展性高,灵活
    • 易于实现简单的文法
  • 缺点
    • 可使用场景少
    • 对于复杂的文法较难维护
    • 会引起类膨胀

2. 代码示例

2.1 设计

需求:COS的设计

  • 定义一个上下文,用来对字串做表达前的处理。
    • 本例中只需要将字串切割成字符列表备用。
  • 定义一个抽象表达式
    • 它由加、减两、数值三个具体表达式分别实现
      • 只是一个表达式,被客户端组装之后才能显示它的实际作用。
  • 定义一个客户端
    • 持有上下文,意味着他可以实例化一个上下文来对COS的字串做表达前的处理。
    • 持有表达式,意味着它可以实例化并组装一个表达式

2.2 代码

  • 代码
package mainimport ("fmt""strconv""strings"
)// 定义一个抽象表达式
type Node interface {Interpreter() int
}// 定义终结表达式
type ValNode struct {val int
}func (v *ValNode) Interpreter() int {return v.val
}// 定义非终结表达式——加法
type AddNode struct {left  Noderight Node
}func (a *AddNode) Interpreter() int {return a.left.Interpreter() + a.right.Interpreter()
}// 定义非终结表达式——减法
type SubNode struct {left  Noderight Node
}func (s *SubNode) Interpreter() int {return s.left.Interpreter() - s.right.Interpreter()
}// 定义上下文
type Context struct {exp   []stringindex int
}// 它的方法负解释前的所有处理
func (c *Context) GetList(exp string) {c.exp = strings.Split(exp, " ")
}// 定义客户端,它持有上下文和解释器
type Client struct {context Contextprev    Node
}// 构造表达式
func (p *Client) CreateNode(expString string) Node {p.context = Context{}p.context.GetList(expString)for {if p.context.index >= len(p.context.exp) {return p.prev}switch p.context.exp[p.context.index] {case "+":p.prev = p.CreateAddNode()case "-":p.prev = p.CreateSubNode()default:p.prev = p.CreateValNode()}}}// 三个方法用来创建node并参与表达式的拼装
func (p *Client) CreateAddNode() Node {p.context.index++return &AddNode{left: p.prev, right: p.CreateValNode()}
}func (p *Client) CreateSubNode() Node {p.context.index++return &SubNode{left: p.prev, right: p.CreateValNode()}
}func (p *Client) CreateValNode() Node {v, _ := strconv.Atoi(p.context.exp[p.context.index])p.context.index++return &ValNode{v}
}func main() {//实例化一个客户端p := &Client{}//拼装表达式node := p.CreateNode("1 + 5 - 3")//调用表达式得到结果result := node.Interpreter()//验证结果(实际应用中应该由客户端验证,我们这里打印出来口算验证一下好了。)fmt.Println(result)
}
  • 输出
3

2.3 类图

Client
+context:Context
+prev:Node
+CreateNode(expString string) : Node
+CreateAddNode() : Node
+CreateSubNode() : Node
+CreateValNode() : Node
Context
+exp:[]string
+index:int
+GetList(exp string)
«interface»
Node
+Interpreter() : int
ValNode
+val:int
+Interpreter() : int
AddNode
+left:Node
+right:Node
+Interpreter() : int
SubNode
+left:Node
+right:Node
+Interpreter() : int
http://www.lryc.cn/news/213911.html

相关文章:

  • Windows个性化颜色睡眠后经常改变
  • calico ipam使用
  • Redis系统学习(高级篇)-Redis持久化-AOF方式
  • 云安全-云原生基于容器漏洞的逃逸自动化手法(CDK check)
  • 精选10款Python可视化工具,请查收
  • 大数据(21)-skew-GroupBy
  • window压缩包安装mongodb并注册系统服务
  • 【Java每日一题】——第四十五题:综合案例:模拟物流快递系统。(2023.11.1)
  • 二十二、Arcpy批量波段组合——结合Landat数据城市建成区提取
  • 电脑上数据恢复的详细操作
  • 3.1 linux控制内核打印printk demsg DEBUG
  • 关于爬虫API常见的技术问题和解答
  • 在CentOS上用yum方式安装MySQL8过程记录
  • CEYEE希亦新品洗地机Pro系列发布, 领跑行业的「水汽混动」技术的旗舰新杰作
  • 为什么要安装防静电门禁闸机
  • [linux] shell中的()和{}
  • jdk官网下载(详细步骤)
  • 10.24 校招 实习 内推 面经
  • Pico Neo4、Neo3开发手柄的使用交互监听
  • 【k8s】pod详解
  • 优思学院:质量管理7原则、8大要点
  • 自动化测试如何解析excel文件?
  • 职场好物:乐歌M9S升降办公电脑台,告别久坐办公,升职加薪就选它
  • springboot+vue基于Hadoop短视频流量数据分析与可视化系统的设计与实现【内含源码+文档+部署教程】
  • 审核 Microsoft SQL Server 日志
  • 【NLP】什么是语义搜索以及如何实现 [Python、BERT、Elasticsearch]
  • 【JavaScript】JS基础语法
  • 06-云计算概览及问题关注
  • 怎么监控钉钉聊天记录内容(监控钉钉聊天记录的3种形式)
  • 深入理解强化学习——强化学习的历史:时序差分学习