zoukankan      html  css  js  c++  java
  • Atitit.java expression fsm 表达式分词fsm引擎

    Atitit.java expression fsm 表达式分词fsm引擎

     

    C:workspaceAtiPlatf_cmssrccomattilaxfsmJavaExpFsm.java

     

     

    String code = "new(com.attilax.util.connReduceDync).set_resfile(uc_js.txt).joinNout() "

    .trim();

     

     

    $code=new(com.attilax.user.AgentService).login(admin,admin)

     

    [

    "new",

    "(",

    "com.attilax.user.AgentService",

    ")",

    ".",

    "login",

    "(",

    "admin",

    "admin",

    ")"

    ]

     

     

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

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

     

     

     

    package com.attilax.fsm;

     

    import java.util.List;

     

    import com.google.common.collect.Lists;

     

    public class JavaExpFsm {

    List<String> tokens = Lists.newLinkedList();

    String curToken = "";

    //String splitors = "(),"";

    String curStat = "ini";

    private String code;

    public char[] code_char_arr;

     

    public JavaExpFsm(String code) {

    this.code = code;

    }

     

    /**

     * http://localhost/new(com.attilax.util.connReduceDync).set_resfile(uc_js.txt).joinNout()

     * http://localhost/wrmiServlet?code=new(com.attilax.util.connReduceDync).set_resfile(uc_js.txt).joinNout()

     * @param args

     */

    public static void main(String[] args) {

    String code = "new(com.attilax.util.connReduceDync).set_resfile(uc_js.txt).joinNout() "

    .trim();

    code= " new(com.attilax.agent.AgentRechargeService).getSubMemTotalsRecycleByAgentId("promoter:$pid$,fld2:v2")";

    List li = new JavaExpFsm(code).getTokens();

    for (Object object : li) {

    System.out.println(object);

    }

    System.out.println(li);

     

    }

     

    public List getTokens() {

    code_char_arr = code.toCharArray();

    for (char c : code_char_arr) {

    // get next char,,then change stat

    // jude cur char and cur stat...then if or not chage stat

    if (c == '(' && !this.curStat.equals("strStart")) {    //&&  cur stta=ini

    this.curStat = "brkStart";

    tokens.add(this.curToken);

    tokens.add("(");

    this.curToken = "";

    continue;

    }

     

    //if (c == '.' && this.curStat.equals("brkStart")) {

    //

    //curToken = curToken + String.valueOf(c);

    //continue;

    //

    //// this.curStat.equals("brkEnd"))

    //

    //}

    //

    if (c == ')'  && !this.curStat.equals("strStart") ) {    //&& cur stat =brk start

    this.curStat = "brkEnd";

    if(this.curToken.length()>0)

    tokens.add(this.curToken);

    tokens.add(")");

    this.curToken = "";

    continue;

    }

    if (c == '.' && this.curStat.equals("brkEnd")) {

    tokens.add(".");

    curToken = "";

    continue;

    }

    if(c=='"' && this.curStat.equals("brkStart"))

    {

    this.curStat = "strStart";

    //tokens.add(c);

    this.curToken = "";

    continue;

    }

    if(c=='"' && this.curStat.equals("strStart"))

    {

    this.curStat = "strEnd";

    tokens.add(this.curToken);

    this.curToken = "";

    continue;

    }

    if(c==',' && this.curStat.equals("brkStart"))

    {

    //this.curStat = "strEnd";

    tokens.add(this.curToken);

    this.curToken = "";

    continue;

    }

    //if (this.curStat.equals("ini"))

    curToken = curToken + String.valueOf(c);

    }

    return tokens;

    }

     

    }

     

  • 相关阅读:
    梯度下降的矩阵分解公式推导
    再谈矩阵分解在推荐系统中的应用
    浅谈矩阵分解在推荐系统中的应用
    tomcat局域网内发布html
    通过JavaScript动态生成html控件
    html 复选框checkbox
    HTML <frameset>不同frame之间传值
    OpenLayers 案例一
    ubuntu java开发环境jdk安装
    如何成为Python高手
  • 原文地址:https://www.cnblogs.com/attilax/p/5963300.html
Copyright © 2011-2022 走看看