Atitit.注解and属性解析(2)---------语法分析 生成AST  attilax总结  java .net

1. 应用场景:::因为要使用ui化的注解 1

2. 使用解释器方式来实现生成AST 1

3. 识别TerminalExpression和NonterminalExpression
2

1.1. 单词流必须识别为保留字,标识符(变量),常量,操作符(运算符 )和界符五大类 2

1.2. 操作符(运算符 )::: 2

4. 生成括号操作符表达式 2

5. 逗号操作符表达式 5

6. 等号表达式and 基本元素表达式 6

7. AST 可视化显示 6

1. 应用场景:::因为要使用ui化的注解

String s = "@QueryAdptr(sqlwhere=\" clo1='@p' \",prop2=\"v2\") @Nofilt";

网上马,,子能嘎自实现兰.

作者:: 老哇的爪子 Attilax 艾龙,  EMAIL:1466519819@qq.com

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

2. 使用解释器方式来实现生成AST

Context存储的全局上下文环境,AbstractExpression是所有表达式必须继承的接口,TerminalExpression和NonterminalExpression是两个实现。

3. 识别TerminalExpression和NonterminalExpression

1.1. 单词流必须识别为保留字,标识符(变量),常量,操作符(运算符 )和界符五大类

1.2. 操作符(运算符 ):::

() [] -> .

? :

条件

由右向左

() [] -> .

括号(函数等),数组,两种结构成员访问

由左向右

,

逗号(顺序)

+ -

加,减

由左向右

括号,纺括号,等号

参考

编译器DIY——词法分析 - GodLike - 博客频道 - CSDN.NET.htm

操作符要使用一个状态来描述的...

4. 生成括号操作符表达式

// 构造函数传参,并解析

public Client(String expStr) throws CantFindRitBrack {

// 定义一个堆栈,安排运算的先后顺序

Stack<AbstractExpression> stack = ctx.stack;

// 表达式拆分为字符数组

List<Token> tokenList = (List<Token>) fsmx.getTokenList();

// 运算

//AbstractExpression left = null;

//AbstractExpression right = null;

for (int i =0; i < tokenList.size(); i++) {

Token tk = tokenList.get(i);

switch (tk.value) {

case "(": // comma exp

AbstractExpressionleft3 = stack.pop();

int nextRitBrackIdx=getnextRitBrackIdx(i,tokenList);

List sub=tokenList.subList(i+1, nextRitBrackIdx);

AbstractExpressioncenter = new BracktItemExpression(sub,ctx);

center=stack.pop();

stack.push(new BracktExpression(left3, center));

i=nextRitBrackIdx;

break;

case ",": // comma exp

AbstractExpressionleft = stack.pop();

AbstractExpressionright = new CommaItemExpression(new AttrNameExpression(

tokenList.get(++i).value), new EqxlExpression(

tokenList.get(++i).value), new AttValExpression(

tokenList.get(++i).value));

stack.push(new CommaExpression(left, right));

break;

default: // var in gonsi 公式中的变量

AbstractExpression left2 =new AnnoExpression(tokenList.get(i).value);

stack.push(left2);

}

}

// 把运算结果抛出来

this.expression = stack.pop();

}

private int getnextRitBrackIdx(int start, List<Token> tokenList) throws CantFindRitBrack {

for (int i=start;i<tokenList.size();i++) {

if(tokenList.get(i).value.equals(")"))

return i;

}

throw new CantFindRitBrack("");

}

// start calc开始运算

public Object run() {

System.out.println("--");

//CommaExpression ce=(CommaExpression) expression;

AbstractExpression  AST=new ASTrootExpress(expression,new AnnoExpression("tt"));

System.out.println(JSONObject.fromObject(AST).toString(15));

//json

//System.out.println(JsonUtil4jackjson.buildNormalBinder().toJson(

//ce));

return this.expression.interpret(this.ctx);

}

5. 逗号操作符表达式

public class BracktItemExpression extends AbstractExpression {

public BracktItemExpression(List sub2, Context ctx) {

Stack<AbstractExpression> stack = ctx.stack;

List<Token> tokenList = sub2;

for (int i = 0; i < tokenList.size(); i++) {

Token tk = tokenList.get(i);

switch (tk.value) {

case ",": // comma exp

AbstractExpression left = stack.pop();

AbstractExpression right = new CommaItemExpression(

new AttrNameExpression(tokenList.get(++i).value),

new EqxlExpression(tokenList.get(++i).value),

new AttValExpression(tokenList.get(++i).value));

stack.push(new CommaExpression(left, right));

break;

default: // var in gonsi 公式中的变量

AbstractExpression left2 = new CommaItemExpression(

new AttrNameExpression(tokenList.get(i).value),

new EqxlExpression(tokenList.get(++i).value),

new AttValExpression(tokenList.get(++i).value));

stack.push(left2);

}

}

}

6. 等号表达式and 基本元素表达式

7. AST 可视化显示

使用json  缩进15来显示...马个好的tree型显示,都是树放的,马个亘放的...牙马个好的pic lib 输出层次...

{"rootExp": {

"centerExp":                {

"leftComma":                               {

"leftComma":                                              {

"attNameExp": {"attname": "at1"},

"attValExp": {"val": "v1"},

"eqExp": {}

},

"rightCommaExp":                                              {

"attNameExp": {"attname": "at2"},

"attValExp": {"val": " v2 abc "},

"eqExp": {}

}

},

"rightCommaExp":                               {

"attNameExp": {"attname": "at3"},

"attValExp": {"val": "v3"},

"eqExp": {}

}

},

"nameExp": {"value": "@qu"}

}}

Atitit.注解and属性解析(2)---------语法分析 生成AST attilax总结 java .net的更多相关文章

  1. Atitit.注解解析(1)---------词法分析 attilax总结 java .net

    Atitit.注解解析(1)---------词法分析 attilax总结  java .net 1. 应用场景:::因为要使用ui化的注解 1 2. 流程如下::: 词法分析(生成token流) & ...

  2. atitit.自己动手开发编译器and解释器(1) ------词法分析--attilax总结

    atitit.自己动手开发编译器and解释器(1) ------词法分析--attilax总结 1.   应用场景:::DSL 大大提升开发效率 1 2. 2. 流程如下::: 词法分析(生成toke ...

  3. 【lombok】lombok---帮你简化生成必要但臃肿的java代码工具 【映射注解和lombok注解同时使用 以及 映射注解放在属性和get方法上的区别】

    官方地址:https://projectlombok.org/ GitHub:https://github.com/rzwitserloot/lombok 指导说明文档:http://jnb.ociw ...

  4. Spring源码解析 – @Configuration配置类及注解Bean的解析

    在分析Spring 容器创建过程时,我们知道容器默认会加载一些后置处理器PostPRocessor,以AnnotationConfigApplicationContext为例,在构造函数中初始化rea ...

  5. Spring注解式事务解析

    #Spring注解式事务解析 增加一个Advisor 首先往Spring容器新增一个Advisor,BeanFactoryTransactionAttributeSourceAdvisor,它包含了T ...

  6. Spring注解开发-全面解析常用注解使用方法之生命周期

    本文github位置:https://github.com/WillVi/Spring-Annotation/ 往期文章:Spring注解开发-全面解析常用注解使用方法之组件注册 bean生命周期 ​ ...

  7. 使用Spring注解注入属性

    本文介绍了使用Spring注解注入属性的方法.使用注解以前,注入属性通过类以及配置文件来实现.现在,注入属性可以通过引入@Autowired注解,或者@Resource,@Qualifier,@Pos ...

  8. Atitit.html解析器的选型 jsoup nsoup ,java c# .net 版本

    Atitit.html解析器的选型 jsoup nsoup ,java c# .net 版本 1. 框架选型的要求1 1.1. 文档多1 1.2. 跨平台1 2. html解析器特性:1 2.1. j ...

  9. (转)用@Resource注解完成属性装配

    http://blog.csdn.net/yerenyuan_pku/article/details/52858878 前面我们讲过spring的依赖注入有两种方式: 使用构造器注入. 使用属性set ...

随机推荐

  1. Java:volatile 关键字的一点理解

    背景 学了六年C#,一直没有使用过 volatile,对多线程编程也是偶尔才会使用,这次学习 Java 又遇到了 volatile,准备稍微深入的了解一下. volatile 的作用? 几乎所有支持这 ...

  2. Silverlight:《Pro Silverlight5》读书笔记 之 XAML

    XAML Properties and Events in XAML Simple Properties and Type Converters To bridge the gap between s ...

  3. PhD Positions opening at University of Nevada, Reno (Wireless Networking / Cognitive Radio / Wireless Security)

    PhD Positions opening at University of Nevada, RenoDept. of Computer Science and Engineering Researc ...

  4. OpenCV定制化创建角点检测子

    定制化创建角点检测子 目标 在这个教程中我们将涉及: 使用 OpenCV 函数 cornerEigenValsAndVecs 来计算像素对应的本征值和本征向量来确定其是否是角点. 使用OpenCV 函 ...

  5. 8.volatile原子性

    原子性     1.一个操作是不可中断的,即使多个线程在一起执行的时候,一旦操作执行开始,就不会被其他的线程干扰执行并导致执行中断.     2.对于静态变量int ,2个线程同时对它进行修改,线程a ...

  6. js外部样式和style属性的添加移除

    在页面中,往往一个控件的外部样式或者内部样式往往不只一个,而我们只需操作其中一个样式该怎么办呢? 最开始我也不知道该怎么做,就用了最原始的方法,替换原有的样式为新的样式,这样每次都要获取原样式,找通用 ...

  7. Servlet学习笔记(三):HTTP请求与响应

    一.HTTP请求常用方法: Cookie[] getCookies()返回一个数组,包含客户端发送该请求的所有的 Cookie 对象. Enumeration getAttributeNames()返 ...

  8. 微信-js sdk invalid signature签名错误 问题解决

    如果出现 invalid signature,首先可以确定的是你的签名算法有问题.建议:首先查看微信官方网站给出的解决方案,链接为: http://mp.weixin.qq.com/wiki/7/aa ...

  9. DIV CSS布局中绝对定位和浮动用法

    转自:http://developer.51cto.com/art/201009/223337_1.htm 你对DIV CSS布局中绝对定位和浮动的概念及使用是否熟悉,这里和大家分享一下,CSS中,实 ...

  10. STL - C++ 11的Lambda表达式(上)

    Lambda始自C++ 11,是一种在表达式或语句内指定函数行为的定义式. 你可以定义函数行为作为对象,以inline实参的形式传给算法作为predicate(判断式). eg: std:transf ...