资源简介
用java写的LALR编译器,实现语法分析
代码片段和文件信息
/**
* @(#)LALR.java
*
*
* @author Huachunya
* @version 1.00 2009/6/15
*/
import java.io.*;
import java.lang.*;
import java.util.*;
public class LALR {
private Map mapt=new HashMap();//终结符
private Map mapn=new HashMap(); //非终结符
private char map[]=new char[9]; //非终结符
private String pro[]=new String[20];
private int len=0; //产生式的个数
private int cntn=0; //非终结符个数
private int cntt=0; //终结符个数
private char first[][]=new char[9][25];
private char follow[][]=new char[9][25];
private int firstlen[]=new int[9];
private int followlen[]=new int[9];
private String I[][]=new String[200][25];//LALR项目集
private String It[][]=new String [200][25]; //LR后跟的集合
private String Iori[]=new String [25];
private String Itori[]=new String [25];
private int Icnt[]=new int[200];//每个项目集中产生式的个数
private int Ioricnt[]=new int[200];//每个项目集的原始产生式个数
private int Inum=0;//项目集中的个数
private int Taction[][]=new int[200][25];
private int Tgoto[][]=new int[200][10];
private String mstr=null; //要分析的句子
private int escape1[]=new int[25]; //终结符要跟着输出的空格数
private int escape2[]=new int[25];//非终结符
public void InitialProducer() throws NullPointerException{
try{
mapt.clear();
mapt.put(‘a‘“;“); escape1[0]=5;
mapt.put(‘b‘“var“);escape1[1]=3;
mapt.put(‘c‘“id“);escape1[2]=4;
mapt.put(‘d‘“$“);escape1[3]=5;
mapt.put(‘e‘“if“);escape1[4]=4;
mapt.put(‘f‘“then“);escape1[5]=2;
mapt.put(‘g‘“else“);escape1[6]=2;
mapt.put(‘h‘“while“);escape1[7]=1;
mapt.put(‘i‘“do“);escape1[8]=4;
mapt.put(‘j‘“begin“);escape1[9]=1;
mapt.put(‘k‘“end“);escape1[10]=3;
mapt.put(‘l‘“:=“);escape1[11]=4;
mapt.put(‘m‘“:“);escape1[12]=5;
mapt.put(‘n‘“n“);escape1[13]=5;
mapt.put(‘o‘“*“);escape1[14]=5;
mapt.put(‘p‘“(“);escape1[15]=5;
mapt.put(‘q‘“)“);escape1[16]=5;
mapt.put(‘r‘“true“);escape1[17]=2;
mapt.put(‘s‘“false“);escape1[18]=1;
mapt.put(‘t‘“==“);escape1[19]=4;
mapt.put(‘u‘“+“);escape1[20]=5;
mapt.put(‘v‘“#“);escape1[21]=5;
cntt=mapt.size();
mapn.clear();
mapn.put(‘Q‘0);
mapn.put(‘P‘1);
mapn.put(‘D‘2);
mapn.put(‘S‘3);
mapn.put(‘L‘4);
mapn.put(‘E‘5);
mapn.put(‘T‘6);
mapn.put(‘F‘7);
mapn.put(‘B‘8);
cntn=mapn.size();
map[0]=‘Q‘;escape2[0]=5;
map[1]=‘P‘;escape2[1]=5;
map[2]=‘D‘;escape2[2]=5;
map[3]=‘S‘;escape2[3]=5;
map[4]=‘L‘;escape2[4]=5;
map[5]=‘E‘;escape2[5]=5;
map[6]=‘T‘;escape2[6]=5;
map[7]=‘F‘;escape2[7]=5;
map[8]=‘B‘;escape2[8]=5;
len=0;
pro[len++]=“Q-P“;
pro[len++]=“P-DS“;//P-DaS?
pro[len++]=“D-bcaD“;
pro[len++]=“D-d“;
pro[len++]=“S-eBfSgS“;
pro[len++]=“S-hBiS“;
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 19624 2009-06-25 12:39 LALR1\classes\LALR.class
文件 1631 2009-06-25 12:39 LALR1\classes\LALR1.class
文件 899 2009-06-25 12:39 LALR1\LALR1.jcp
文件 284 2009-06-25 12:39 LALR1\LALR1.jcw
文件 2125 2009-06-25 12:39 LALR1\LALR12.jcu
文件 285 2009-06-25 12:39 LALR1\LALR12.jcw
文件 25178 2009-06-25 12:39 LALR1\src\LALR.java
文件 1117 2009-06-25 12:39 LALR1\src\LALR1.java
文件 209 2009-06-25 12:39 LALR1\src_lalr1.txt
目录 0 2009-06-25 12:39 LALR1\classes
目录 0 2009-06-25 12:39 LALR1\src
目录 0 2009-06-25 12:39 LALR1
----------- --------- ---------- ----- ----
51352 12
- 上一篇:网上购物系统设计前台部分和后台部分
- 下一篇:Android音乐播放器89432
相关资源
- mysql数据处理,java用户登录处理
- 法律咨询信息系统(java+jsp+sqlserver)
- Java快速开发平台源码(renren-fast)
- 锐聘学院QST青软JavaWeb十二个打包
- 3.3.6微信支付JAVA版demo
- javaweb网上购物系统源码(附数据库脚
- javaweb校园宿舍系统(附数据库脚本)
- JavaWeb书城项目(附数据库脚本)
- 基于JAVA_JSP电子书系统(源码+数据库
- Java网络编程知识点总结.xmind
- 一站式Java网络编程 BIO-NIO-AIO资料源码
- jsp讲解
- 基于SSH框架的JavaWeb项目—人员信息管
- javaweb实现的邮件收发系统(附数据库
- Java 仿QQ(附客户端以及服务端源码)
- Java TCP IP Socket
- java定时发送邮件(基于quartz)
- Java Swing开发的《星际争霸》游戏
- java+数据库商品交易管理系统(附数据
- 使用java语言编译一个计算器
- java swing工资管理系统(源码+数据库
- JAVALibrary
- 微信企业号回调模式Java版
- 顺丰丰桥接口开发详细教程源码含下
- Java博客概要设计文档
- 药品进销存管理系统(论文范文_JSP
- 奖学金管理系统java+jsp+mysql
- 毕设参考——基于java酒店管理
- Java写的一个简单的字体更改程序
- java8学习教程之lambda表达式的使用方法
评论
共有 条评论