• 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

  • 相关阅读:
    信贷基本词汇英汉对照[突然发现写软件也要被迫学企业管理的一些相关知识....]
    英语学习网站收集
    简单的WindowsForm Client与WebService通信例子[对象的序列化与反序列化]
    .Net String 一些比较少用的Format操作【今天用到的】
    HSSWORKBOOK中读取Excel出现的异常现象
    [Utility.sln]根据MSDN上的DESCryptoServiceProvider 类 尝试写的对称密钥加密原代码[可应用于安全级别不高的数据连接和密码保护]
    SAP Menu Tree
    中国的IT需要这样一种精神...[转载自CSDN.写的很深刻...]
    针式PKM的设计原则
    将你的记忆量减到最少
  • 原文地址:https://www.cnblogs.com/attilax/p/15198691.html
Copyright © 2020-2023  润新知