zoukankan      html  css  js  c++  java
  • Atitit.linq java的原理与实现 解释器模式

    Atitit.linq java的原理与实现 解释器模式

     

     

    1Linq  from  where 的实现1

    2Where expr 的实现1

    3Attilax的一点变化2

    4解释器模式的结构2

    5Code3

    5.1. EqExpression3

    5.2. LikeExpression4

    5.3. AndExpression4

    5.4. AExpression5

    6参考5

     

     

     

    1. Linq  from  where 的实现

    Map rowfrom(ColumnsDefs).where(eq("COLUMN_NAME"key)).exe().get(0);

     

    2. Where expr 的实现

     

    大概有15expr。。。  关系(大小比较),逻辑expr。。。In like 等。。

     

    作者:: 绰号:老哇的爪子 ( 全名::Attilax Akbar Al Rapanui 阿提拉克斯 阿克巴 阿尔 拉帕努伊 ) 汉字名:艾龙,  EMAIL:1466519819@qq.com

    转载请注明来源: http://blog.csdn.net/attilax

     

     

    3. Attilax的一点变化

    没使用终结符号的概念..两个数据类型..express类型,common data..

    要是express类型..就是可以计算的express...  贝儿走普通的数据..

     

    Note::checkSuitOk should  use  interpreter

     

    4. 解释器模式的结构

    · 抽象解释器:声明一个所有具体表达式都要实现的抽象接口(或者抽象类),接口中主要是一个interpret()方法,称为解释操作。具体解释任务由它的各个实现类来完成,具体的解释器分别由终结符解释器TerminalExpression和非终结符解释器NonterminalExpression完成。

    · 终结符表达式:实现与文法中的元素相关联的解释操作,通常一个解释器模式中只有一个终结符表达式,但有多个实例,对应不同的终结符。终结符一半是文法中的运算单元,比如有一个简单的公式R=R1+R2,在里面R1R2就是终结符,对应的解析R1R2的解释器就是终结符表达式。                                

    · 非终结符表达式:文法中的每条规则对应于一个非终结符表达式,非终结符表达式一般是文法中的运算符或者其他关键字,比如公式R=R1+R2中,+就是非终结符,解析+的解释器就是一个非终结符表达式。非终结符表达式根据逻辑的复杂程度而增加,原则上每个文法规则都对应一个非终结符表达式。

     

    仅有两类元素:运算元素和运算符号,运算元素就是指abc等符号,需要具体赋值的对象,也叫做终结符号,为什么叫终结符号呢?因为这些元素除了需要赋值外,不需要做任何处理,所有运算元素都对应一个具体的业务参数,这是语法中最小的单元逻辑,不可再拆分;运算符号就是加减符号,需要我们编写算法进行处理,每个运算符号都要对应处理单元,否则公式无法运行,运算符号也叫做非终结符号

     

    们就可以先画一个简单的类图,如图27-1所示。

    5. Code

    5.1. EqExpression 

    package com.attilax.linq;

     

    import java.util.Map;

     

    public class EqExpression extends AExpression {

     

    public EqExpression(String leftCol, Object ritVal) {

    this.left=leftCol;

    this.rit=ritVal;

    }

    public boolean interpreter(Map row) {

    //LikeExpression le=(LikeExpression) whereExpressAst;

     

    if(row.get(this.left.toString()).toString().equals(this.rit.toString()))

    return true;

    else

    return false;

    }

     

    5.2. LikeExpression 

    package com.attilax.linq;

     

    import java.util.Map;

     

    public class LikeExpression extends AExpression{

     

     

    public LikeExpression(String col, String val) {

    this.left=col;

    this.rit=val;

    }

    public boolean checkSuitOk(Map row) {

    //LikeExpression le=(LikeExpression) whereExpressAst;

    if(row.get(this.left.toString()).toString().contains(this.rit.toString()))

    return true;

    else

    return false;

    }

     

    }

    5.3. AndExpression 

    package com.attilax.linq;

     

    import java.util.Map;

     

    public class AndExpression extends AExpression {

     

    public AndExpression(AExpression whereExpressAst, AExpression eq) {

    this.left=whereExpressAst;

    this.rit=eq;

    }

    public boolean checkSuitOk(Map row) {

    //LikeExpression le=(LikeExpression) whereExpressAst;

    AExpression lft_exp=(AExpression) this.left;

    AExpression rit_exp=(AExpression) this.rit;

    return  lft_exp.checkSuitOk(row) && rit_exp.checkSuitOk(row);

    }

     

    }

    5.4. AExpression 

    package com.attilax.linq;

     

    import java.util.Map;

     

    public class AExpression {

    public Object left;

    public Object rit;

     

    public boolean checkSuitOk(Map row) {

    throw new RuntimeException("no imp in base aexp class");

    }

     

    }

     

     

    6. 参考

    Atitit.linq api 兼容性草案 v2.docx

    23种设计模式(14):解释器模式 卡奴达摩的专栏 博客频道 - CSDN.NET.htm

    解释器模式 详解 疯狂程序员 博客频道 - CSDN.NET.htm

  • 相关阅读:
    最新超详细VMware虚拟机安装完整教程
    Java网络编程 -- AIO异步网络编程
    Java网络编程 -- NIO非阻塞网络编程
    Java网络编程 -- BIO 阻塞式网络编程
    Java网络编程 -- 网络协议
    自定义FutureTask实现
    JDK容器类List,Set,Queue源码解读
    JDK容器类Map源码解读
    深入理解Java中的锁(三)
    深入理解Java中的锁(二)
  • 原文地址:https://www.cnblogs.com/attilax/p/15198691.html
Copyright © 2011-2022 走看看