说实话,这种设计模式太抽象了,使用场景也比较少,基本上也不会用到,大家先来基本了解下就行了。
解释器模式提供了一种解释语言的语法或表达式方法。
举个例子我们要输出 a开头,c结尾,中间是任意个b的字符串。
于是我们定义
S::=aA*c
A::=b
::=表示推导,*表示可以有0到N个重复
描述这个集合的文法,称为形式文法。
描述得是形式语言,定义的是形式文法。
使用场景
1.如果某个的简单的而语言需要解释执行,且可以将该语言中的语句表示为一个抽象语法树。
比如加减运算p+q+m-n可以表示为:
2.在某些特定的领域出现不断重复的问题时,可以将该领域的问题转化为一种语法规则下的语句,然后构建解释起来解释该语句。比如字符串的大小写转化,阿拉伯数字转化为中文的数字等。
实战:
表达式m+n+p我们来进行解释。
注意:“+”是非终结符号,m、n、p是非终结符号。
首先定一个抽象算术运算解释器ArithmeticExpression,里面有一个抽象的解释方法interpreter,返回具体解析到的值。
两个具体子类实现它:
1.数字解释器NumExpression,狗仔函数传入num=传入的数字,interpreter返回num;
2.加法运算解释器,构造函数传入了两个ArithmeticExpression类型解释器对象,保存为成员变量exp1、exp2,其实也就是保存了+两边的数字解释器。
最后interpreter方法进行运算,并且返回运算结果。
return exp1.interpreter() + exp2.interpreter();
我们的解释器就实现完成了
使用:
把m + n + p注意中间带有空格用来splite每一个字符得到数组elems[]; 遍历数组,如果遇到数字就创建Num解释器,并且压入栈,如果遇到符号就把上一个栈弹出来,并且把下一个字符也生成Num解释器,作为两个参数创建AdditionExpression解释器,然后把运算解释器压入栈。
最后调用栈.pop().interpreter();就能得到结果
Android中的实现
Android中使用解释器模式太少了,有一个地方,我们在AndroidMaifext.xml里面定义的配置项,就是PackagePaser的parsePackage方法来翻译解释的。
优点:灵活的扩展性,需要扩展的时候,增加非终结符解释器即可。
缺点:每条文法都有一个解释器,类太多,后期维护困难,且如果文法复杂,构建抽象语法树会异常繁琐。