快速业务通道

深入浅出基于Java的解释器设计模式 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-23
ssion left , Expression right)   {    this.left = left ;    this.right= right ;   }   public int interpret(Context con)   {    return left.interpret(con) + right.interpret(con);   } } class Subtract extends Expression {   private Expression left , right ;   public Subtract(Expression left , Expression right)   {    this.left = left ;    this.right= right ;   }   public int interpret(Context con)   {    return left.interpret(con) - right.interpret(con);   } } class Multiply extends Expression {   private Expression left , right ;   public Multiply(Expression left , Expression right)   {    this.left = left ;    this.right= right ;   }   public int interpret(Context con)   {    return left.interpret(con) * right.interpret(con);   } } class Division extends Expression {   private Expression left , right ;   public Division(Expression left , Expression right)   {    this.left = left ;    this.right= right ;   }   public int interpret(Context con)   {    try{     return left.interpret(con) / right.interpret(con);    }catch(ArithmeticException ae)    {     System.out.println("被除数为0!");     return -11111;    }   } } //测试程序,计算 (a*b)/(a-b+2) public class Test {   private static Expression ex ;   private static Context con ;   public static void main(String[] args)   {    con = new Context();    //设置变量、常量    Variable a = new Variable();    Variable b = new Variable();    Constant c = new Constant(2);    //为变量赋值    con.addValue(a , 5);    con.addValue(b , 7);    //运算,对句子的结构由我们自己来分析,构造    ex = new Division(new Multiply(a , b), new Add(new Subtract(a , b) , c));    System.out.println("运算结果为:"+ex.interpret(con));   } }

解释器模式并没有说明如何创建一个抽象语法树,因此它的实现可以多种多样,在上面我们是直接在Test中提供的,当然还有更好、更专业的实现方式。

对于终结符,GOF建议采用享元模式来共享它们的拷贝,因为它们要多次重复出现。但是考虑到享元模式的使用局限性,我建议还是当你的系统中终结符重复的足够多的时候再考虑享元模式。

四、优缺点

解释器模式提供了一个简单的方式来执行语法,而且容易修改或者扩展语法。一般系统中很多类使用相似的语法,可以使用一个解释器来代替为每一个规则实现一个解释器。而且在解释器中不同的规则是由不同的类来实现的,这样使得添加一个新的语法规则变得简单。

但是解释器模式对于复杂文法难以维护。可以想象一下,每一个规则要对应一个处理类,而且这些类还要递归调用抽象表达式角色,多如乱麻的类交织在一起是多么恐怖的一件事啊!

五、总结

这样对解释器模式应该有了些大体的认识了吧,由于这个模式使用的案例匮乏,所以本文大部分观点直接来自于GOF的原著。只是实例代码是亲自实现并调试通过的。

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号