13-解释器模式Quarkus实现

本文通过一个实例详细介绍了如何使用Quarkus框架实现设计模式中的解释器模式,包括模式的基本概念、角色解析,并提供了具体的代码实现和UML模型。项目涉及不同部门对项目的解释,通过抽象表达式、终端表达式和非终结符表达式的角色分工,展示了解释器模式在实际场景中的应用。
摘要由CSDN通过智能技术生成

摘要:本文用一个实例场景描述Gof 23设计模式中的解释器模式,并用Quarkus框架代码给予实现,同时也给出实现代码的UML模型。
关键字:Gof 23 设计模式 解释器模式 Quarkus

1 基础知识
1.1 标准定义
解释器(Interpreter)模式标准定义:给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。
1.2 分析和说明
解释器(Interpreter)模式属于行为型设计模式。其含义是给定一个语言后,解释器模式可以定义出其文法的一种表示,并同时提供一个解释器。客户端可以使用这个解释器来解释这个语言中的句子。解释器模式将描述怎样在有了一个简单的文法后,使用模式设计解释这些语句。在解释器模式里面提到的语言是指任何解释器对象能够解释的任何组合。在解释器模式中需要定义一个代表文法的命令类的等级结构,也就是一系列的组合规则。每一个命令对象都有一个解释方法,代表对命令对象的解释。命令对象的等级结构中的对象的任何排列组合都是一个语言。
解释器(Interpreter)模式结构如图1所示,其角色包括抽象表达式(AbstractExpression)角色、络结符表达式(Terminal Expression)角色、非终结符表达式(Nonterminal Expression)角色、客户端(Client)角色和环境(Context)角色等。其描述如下。 在这里插入图片描述
图1 解释器模式结构
抽象表达式(AbstractExpression)角色:声明一个所有的具体表达式角色都需要实现的抽象接口。这个接口主要是一个interpret()方法,称做解释操作。
络结符表达式(Terminal Expression)角色:这是一个具体角色。实现了抽象表达式角色所要求的接口,主要是一个interpret()方法。文法中的每一个终结符都有一个具体终结表达式与之相对应。
非终结符表达式(Nonterminal Expression)角色:这是一个具体角色。文法中的每一条规则R=R1R2…Rn都需要一个具体的非终结符表达式类。对每一个R=R1R2…Rn中的符号都持有一个静态类型为Expression的实例变量。实现解释操作,即interpret()方法。解释操作以递归方式调用上面所提到的代表R1R2…Rn中的各个符号的实例变量。
客户端(Client)角色:代表模式的客户端它有以下功能。建造一个抽象语法树(AST或者Abstract Syntax Tree)调用解释操作interpret()。在一般情况下,模式还需要一个环境角色。
环境(Context)角色:提供解释器这外的一些全局信息,比如变量的真实量值等。

2 应用场景举例
比如公司接了一个项目,不同的部门对项目有不同的了解。技术部门从技术角度来说明这个项目的情况,而市场部从市场角度来诠释这个项目,财务部门从财务角度来解释这个项目。这就可以采用解释器模式。用例如图2所示。
在这里插入图片描述
图2 解释器模式用例图
在这里可以把AbstractExpression类理解为抽象表达式(AbstractExpression)角色。FinancialDepExpression类文件,MarketDepExpression类文件和TechnicalDepExpression类文件是络结符表达式(Terminal Expression)角色。Project类是环境(Context)角色。其实现类图如图3所示。AbstractExpression类为抽象类,FinancialDepExpression具体类,MarketDepExpression具体类和TechnicalDepExpression具体类继承AbstractExpression抽象类。Project类与AbstractExpression类是依赖关系。 在这里插入图片描述
图3 解释器模式类图
解释器模式实现顺序图见图4,实现顺序描述:① 创建一个project1对象;② 创建一个FinancialDepExpression对象并把project1对象赋值给它;③ 创建一个MarketDepExpression对象并把project1对象赋值给它;④ 创建一个TechnicalDepExpression对象并把project1对象赋值给它;⑤ FinancialDepExpression对象对project1对象进行解释;⑥ MarketDepExpression对象对project1对象进行解释;⑦ echnicalDepExpression对象对project1对象进行解释。 在这里插入图片描述
图4 解释器模式实现顺序图

3.Quarkus的实现程序代码
Quarkus程序实现主要包括Project类文件,AbstractExpression抽象类文件,FinancialDepExpression类文件,MarketDepExpression类文件和TechnicalDepExpression类文件等5个文件。其关系如图3所示。下面分别列出这5个文件的程序代码,最后列出测试代码并显示输出结果。
Project类程序代码清单01所示。
程序代码清单01

@ApplicationScoped
public class Project {	
	private String projectName;
	
	public Project (){}
	
	public Project (String name){
		projectName =  name;
	}

	public String getProjectName() {
		return projectName;
	}

	public void setProjectName(String projectName) {
		this.projectName = projectName;
	}
}

AbstractExpression抽象类程序代码清单02所示。
程序代码清单02

public abstract class AbstractExpression {
	public void interpret(Project project){};
}

FinancialDepExpression类、MarketDepExpression类和TechnicalDepExpression类继承AbstractExpression抽象类,其程序代码清单03所示。
程序代码清单03

@ApplicationScoped
public class FinancialDepExpression extends AbstractExpression{
	public void Interpret(Project project){
		System.out.println("财务部对"+project.getProjectName()+"的理解。");		
	}	
}

@ApplicationScoped
public class MarketDepExpression extends AbstractExpression{
	public void Interpret(Project project){
		System.out.println("市场部对"+project.getProjectName()+"的理解。");		
	}
}

@ApplicationScoped
public class TechnicalDepExpression extends AbstractExpression{
	public void Interpret(Project project){
		System.out.println("技术部对"+project.getProjectName()+"的理解。");		
	}
}

解释器模式测试程序的代码清单04如下:
程序代码清单04

public class InterpreterClient implements QuarkusApplication {
	@ConfigProperty(name = "gof23.behavioralpattern.interpreter.title", defaultValue = "gof23")
	String title;
	
	@Inject	Project project1;	
	@Inject	FinancialDepExpression financialDepExpression;	
	@Inject	MarketDepExpression marketDepExpression;	
	@Inject	TechnicalDepExpression technicalDepExpression;
	
	@Override
	public int run(String... args){		
		System.out.println("———————" + title + "演示输出—————————");	
				
		project1.setProjectName("ProjectA");
		List<AbstractExpression> expressList = new ArrayList<AbstractExpression>();
	
		expressList.add(financialDepExpression);
		expressList.add(marketDepExpression);
		expressList.add(technicalDepExpression);

		for (int i = 0; i < expressList.size(); i++) {
			expressList.get(i).Interpret(project1);
		}		
		return 0;		
	}
	
	public static void main(String... args) {
		Quarkus.run(InterpreterClient.class, args);
	}
}

解释器模式测试类输出结果如下所示:

财务部对ProjectA的理解。
市场部对ProjectA的理解。
技术部对ProjectA的理解。

4. 相关Quarkus程序源码下载
可以直接从github上获取代码,读者可以从github上clone预先准备好的示例代码。

git clone https://github.com/rengang66/quarkus-sample-gof23.git

这是一个Maven项目,然后Maven导入工程。该程序位于“src\main\java\com\iiit\quarkus\sample\gof23\behavioralpattern\interpreter”目录中。
同时也可以从gitee上clone预先准备好的示例代码,命令如下:

git clone https://gitee.com/rengang66/quarkus-sample-gof23.git

参考文献

[1] E.Gamma, R.Helm, R.Johnson, and Vlissides. Design Patterns Elements of Reusable Object Oriented Software. Addison-Wesley, 1995
[2] E.Gamma, R.Helm, R.Johnson, and Vlissides.著,李英军等译,设计模式:可复用面向对象软件的基础,北京:机械工业出版社.2000.9.
[3] 阎宏,Java与模式,北京:电子工业出版社. 2002.10
[4] 王俊峰 戚晓滨. 设计模式和UML. 计算机应用研究,1999.16(5), 27-29,39.
[5] 陈琴 朱正强. UML在设计模式描述中的应用. 计算机工程与设计,2003.24(4), 81-84.
[6] 廖兴 尹俊文 蔡放. 基于Java语言的抽象语法树的创建与遍历. 长沙大学学报,2004.18(4), 50-53,57.
[7] 高勇 吴健. 语言解释器的面向对象构造模式. 计算机应用,2003.(z2), 254-257.
[8] Quarkus官网. https://quarkus.io/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值