首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 网络安全-> 教你一招
javaCC学习笔记-JSP教程,Java技巧及代码
作者:网友供稿 点击:697
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 

javacc的功能和yacc相似,主要根据bnf范式生成解析程序,不过javacc是集合了词法分析和语法分析生成java解析代码,主页为:https://javacc.dev.java.net/

javacc有三个工具

javacc 用来处理语法文件(jj)生成解析代码;

jjtree 用来处理jjt文件,生成树节点代码和jj文件,然后再通过javacc生成解析代码;

jjdoc 根据jj文件生成bnf范式文档(html)

javacc使用的各种语言的grammar 文件这里有很多http://www.cobase.cs.ucla.edu/pub/javacc/ ,例如html,xml,python,vb…..,很多足够用了,呵呵。



javacc 的使用

javacc生成的文件中,最主要的是《grammar》.java这个就是解析器的主程序了了,《grammar》名由jj中定义。



现在根据例子说明jj文件的定义:

bnf范式为:

expression
::=
( ( <newline> )* simple_expression <newline> )* <eof>

simple_expression
::=
term ( addop term )*

addop
::=
<plus>


|
<minus>

term
::=
factor ( mulop factor )*

mulop
::=
<timers>


|
<over>

factor
::=
<id>


|
<num>


|
<minus>


|
<plus>


|
<lparen> simple_expression <rparen>




/*这是一个整数的四则运算的例子*/

/* 运行 javacc grammar.jj

javac *.java

java grammar

>>> 1+1*(1+1)

3

>>>^z

*/



parser_begin(grammar) /*解析代码的入口*/



public class grammar {



public static final int plusop=1;

public static final int minusop=2;

public static final int timersop=3;

public static final int overop=4;





public static void main(string args[]) throws parseexception {

grammar parser = new grammar(system.in);



parser.expression();

}

}



parser_end(grammar)



skip : /* 不处理的字符*/

{

" " | "\t"

}



token : /*生成token的字符定义*/

{



< id: ["a"-"z","a"-"z","_"] ( ["a"-"z","a"-"z","_","0"-"9"] )* >



| < num: ( ["0"-"9"] )+ >



| < plus: "+" >



| < minus: "-" >



| < timers: "*" >



| < over: "/" >



| < lparen: "(" >



| < rparen: ")" >

| <newline: ("\r\n"|"\n"|"\r")>

}







void expression() :

/*完成 expression ::=( ( <newline> )* simple_expression <newline> )* <eof> 的配陪*/

{



int value=0; /* 这个{}中是expression()的定义的局部变量*/



}



{



{

system.out.print(">>>");

}

( (<newline> /* 首先匹配newline 这个taken,完成后转到下一个解析*/

{

system.out.print(">>>"); /*在<newline>下的{}中为如果匹配到<newline>执行的java代码。*/

}

)* value= simple_expression() <newline> /*在换行之前simple_expression()解析表达式 ,输入换行后,一个预算解析完成*/



{system.out.println(value);

system.out.print(">>>");/*在<newline>下的{}中为完成表达式解析,匹配到<newline>执行的java代码。*/



}

)*

<eof> /*系统定义的taken,输入结束符*/

}



int simple_expression() :

/*完成simple_expression ::=bnf term ( addop term )*配陪 */

{

/* 这个{}中是simple_expression()的定义的局部变量*/



int value;



int tvalue;



int op;



}



{



value= term (){} /*配陪term 相*/



(



op=addop() tvalue=term()



{

switch(op)

{

case plusop:

value=value+tvalue;

break;

case minusop:

value=value - tvalue;

break;

}

}

)* /*匹配 ( addop term )* */

{ return value; }

}



int addop() : {}

{

<plus> { return plusop; }

| <minus> { return minusop; }

}



int term() :

{

int value;

int tvalue;

int op;

}

{

value=factor(){}

(

op=mulop() tvalue=factor()

{

switch(op)

{

case timersop:

value=value * tvalue;

break;

case overop:

value=value / tvalue;

break;

}

}



)*

{

return value;

}

}

int mulop() :{}

{

<timers> { return timersop; }

| <over> { return overop; }

}



int factor() :

{

int value;

token t;

}

{

t=<id> /*获得<id>的解析的值*/

{

value=100;

return value;



}

|

t=<num>

{

value= (integer.valueof(t.image)).intvalue();

return value;

}

|

t=<minus>

{

value=0-factor();

return value;

}

|

t=<plus>

{



value=factor();

return value;

}

|



<lparen> value=simple_expression() <rparen>

{

return value;

}

}



根据例子: 基本上是一个taken下跟一个{}用于处理当前tabkn的java代码





jjtree的使用:



jjtree的使用,需要根据实际情况写自己的node类,但是都必须实现node.java接口,jjtree提供一个simplenode.java的简单实现,也可以继承它,或者重写这个类。



给出一个javacc自己带例子,也是四则运算:

语法定义:

start
::=
expression ";"

expression
::=
additiveexpression

additiveexpression
::=
( multiplicativeexpression ( ( "+" | "-" ) multiplicativeexpression )* )

multiplicativeexpression
::=
( unaryexpression ( ( "*" | "/" | "%" ) unaryexpression )* )

unaryexpression
::=
"(" expression ")"


|
identifier


|
integer

identifier
::=
<identifier>

integer
::=
<integer_literal>






options {

multi=true;

visitor=true; /*实现匹配的visitor模式代码*/

node_default_void=true; /* 解析函数默认不生成node类*/

}

/*jtt 默认的生成node类名,都带ast前缀加上当前解析的语意的名称*/



parser_begin(eg4)



class eg4 {

public static void main(string args[]) {

system.out.println("reading from standard input...");

eg4 t = new eg4(system.in);

try {

aststart n = t.start();

eg4visitor v = new eg4dumpvisitor();

n.jjtaccept(v, null);

system.out.println("thank you.");

} catch (exception e) {

system.out.println("oops.");

system.out.println(e.getmessage());

e.printstacktrace();

}

}

}



parser_end(eg4)

skip :

{

" "

| "\t"

| "\n"

| "\r"

| <"//" (~["\n","\r"])* ("\n"|"\r"|"\r\n")>

| <"/*" (~["*"])* "*" (~["/"] (~["*"])* "*")* "/">

}



token : /* literals */

{

< integer_literal:

<decimal_literal> (["l","l"])?

| <hex_literal> (["l","l"])?

| <octal_literal> (["l","l"])?

>

|

< #decimal_literal: ["1"-"9"] (["0"-"9"])* >

|

< #hex_literal: "0" ["x","x"] (["0"-"9","a"-"f","a"-"f"])+ >

|

< #octal_literal: "0" (["0"-"7"])* >

}



token : /* identifiers */

{

< identifier: <letter> (<letter>|<digit>)* >

|

< #letter: ["_","a"-"z","a"-"z"] >

|

< #digit: ["0"-"9"] >

}



aststart start() #start : {} /* #start生成定义的节点类,名称为 前缀 + start.java*/

{

expression() ";"

{ return jjtthis; }

}





void expression() : {}

{

additiveexpression()

}



void additiveexpression() : {}

{

(

multiplicativeexpression() ( ( "+" | "-" ) multiplicativeexpression() )*

) #add(>1) /* add # 当满足条件(>1),add生成定义的节点类,名称为 前缀 + add.java*/

}



void multiplicativeexpression() : {}

{

(

unaryexpression() ( ( "*" | "/" | "%" ) unaryexpression() )*

) #mult(>1) /* # mult 当满足条件(>1),mult生成定义的节点类,名称为 前缀 + mult.java*/



}



void unaryexpression() : {}

{

"(" expression() ")" | identifier() | integer()

}



void identifier() #myotherid : /* # myotherid生成定义的节点类,名称为 前缀 + myotherid.java*/

{

token t;

}

{

t=<identifier>

{

jjtthis.setname(t.image);

}

}



void integer() #integer : {} /* # integer生成定义的节点类,名称为 前缀 + integer.java*/



{

<integer_literal>

}





jjdoc的使用很简单 。





如果需要生成其它语言的(例如c#)解析器,除了处理c的yacc和lex外,antlr(http://www.antlr.org/)也是一个不错的选择。



文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·Java 中开源的CMS系统-JSP教程,Java技巧及代码
·ASP.NET服务器控件发送脚本-ASP教程,远程脚本
·javaCC学习笔记-JSP教程,Java技巧及代码
·asp.net中的模态对话框-ASP教程,ASP应用
·在.net应用程序中使用用户控件-.NET教程,组件控件开发
·身份证15位转换成18位代码(vbscript)-ASP教程,脚本编码
·基于dsp控制的数字式双向dc/dc变换器的实现
·利用Asp.net 动态创建DataList-ASP教程,ASP应用
·最佳的数据库分页方法-ASP教程,数据库相关
·利用JAVA技术进行XML编程(第一部分)-JSP教程,Java与XML
最新文章
·网关防护做得好web威胁少一半_教你一招教程
·计算机安全十大建议_教你一招教程
·给ie加个参数 永远不怕ie主页被修改_教你一招教程
·修改十四项设置 打造安全牢靠易用电脑_教你一招教程
·论垂直搜索引擎存在的意义_站长心得
·简单分析个人网站最缺少的几点要素_站长心得
·个人网站赢利探讨:网站究竟是如何盈利的?_站长心得
·网站设计的思考网页版面布局的原理_站长心得
·建立用自己域名结尾的hotmail邮箱2_站长心得
·随时保障系统安全五步搞定补丁管理部署_教你一招教程
相关主题
  • JavaCC的安装-JSP教程,Java技巧及代码
  • javac-----Java编程语言编译器-JSP教程,Java技巧及代码
  • 西部数码虚拟主机

    友情链接
    CNNIC 西部数码
    万网 自助建站
    虚拟主机 asp空间
    域名注册 域名
    域名申请 主页空间
    论坛空间 网站空间
    国际域名 虚拟空间
    空间租用 DDOS防火墙
    成都主机托管 四川主机托管
    主机租用 服务器租用
    网站目录 自助建站
    虚拟主机 网址大全
    软件下载
    自助链接
    虚拟主机资讯 特价虚拟主机
    版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
    关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
    特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
    发表评论 打印  刷新     关闭