美文网首页Android知识Android开发Android技术知识
每日Android源码设计模式之-9、解释器模式

每日Android源码设计模式之-9、解释器模式

作者: Alexey | 来源:发表于2017-03-22 07:08 被阅读0次

    说实话,这种设计模式太抽象了,使用场景也比较少,基本上也不会用到,大家先来基本了解下就行了。


    解释器模式提供了一种解释语言的语法或表达式方法。

    举个例子我们要输出 a开头,c结尾,中间是任意个b的字符串。

    于是我们定义

    S::=aA*c

    A::=b

    ::=表示推导,*表示可以有0到N个重复

    描述这个集合的文法,称为形式文法。

    描述得是形式语言,定义的是形式文法。


    使用场景

    1.如果某个的简单的而语言需要解释执行,且可以将该语言中的语句表示为一个抽象语法树。

    比如加减运算p+q+m-n可以表示为:

    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方法来翻译解释的。


    优点:灵活的扩展性,需要扩展的时候,增加非终结符解释器即可。

    缺点:每条文法都有一个解释器,类太多,后期维护困难,且如果文法复杂,构建抽象语法树会异常繁琐。

    相关文章

      网友评论

        本文标题:每日Android源码设计模式之-9、解释器模式

        本文链接:https://www.haomeiwen.com/subject/hxxznttx.html