MyUtil.java

package Util;

import Value_Final.RRule;

public class MyUtil {
/**
* 判断字符串是否是关键字
* @param key 要判断的字符串
* @return 是否找到
* */
public static boolean isKeyValue(String key){
for(int i=0;i< RRule.KEY_VALUE.length;i++){
if(key.equals(RRule.KEY_VALUE[i])){
return true;
}
}
return false;
}
/**
* 判断字符串是否是双分界符
* @param key 要判断的字符串
* @return 是否找到
* */
public static boolean isDoubleDivider(String key){
for(int i=0;i< RRule.DOUBLE_DIVIDER.length;i++){
if(key.equals(RRule.DOUBLE_DIVIDER[i])){
return true;
}
}
return false;
}
/**
* 判断字符串是否是单分界符
* @param key 要判断的字符串
* @return 是否找到
* */
public static boolean isSignalDivider(String key){
for(int i=0;i< RRule.SIGNAL_DIVIDER.length;i++){
if(key.equals(RRule.SIGNAL_DIVIDER[i])){
return true;
}
}
return false;
}
/**
* 判断字符串是否是字母还是数字
* @param key
* @return 1 是字母 0 是数字 -1 异常
* */
public static int isWordsOrNumber(char key){
int number=(int)key;
if((number>='A'&&number<='Z')||(number>='a'&&number<='z')){
return 1;
}else if(number>='0'&&number<='9'){
return 0;
}else {
return -1;
}
}
/**
* 判断字符串是否是数字
* @param ss
* @return
* */
public static Boolean isNumber(String ss){
for(int i=0;i<ss.length();i++){
if(isWordsOrNumber(ss.charAt(i))!=0){
return false;
}
}
return true;
}
}

RRule.java

package Value_Final;

/**
* 一些常用变量规则
* */
public class RRule {
//关键字 规则
public static final String[] KEY_VALUE={"abstract","assert","boolean","break","byte","case","catch","char",
"class","const","continue","default","do","double","else","enum","extends","final","finally",
"float","for","goto","if","implements","import","instanceof","int","interface","long","native",
"long","native","new","package","private","protected","public","return","short","static","super",
"switch","this","throw","throws","try","void","while"}; public static final String[] SIGNAL_DIVIDER={"=","+","-","*","(",")","{","}",";",":",","};
public static final String[] DOUBLE_DIVIDER={"==",">=","<=","!="}; }

Analysis,java

import Util.MyUtil;

import java.util.Scanner;

public class Analysis {
public static void main(String[] args) {
String inputCode=getInputString();
String spiltItem[]=inputCode.split(" ");
for(String item:spiltItem){
if (MyUtil.isKeyValue(item)){
System.out.println(item);//输出关键字
}else if(MyUtil.isSignalDivider(item)){
System.out.println(item);
}else {//不是关键字则有可能是好几种情况 if(item.contains(";")){//解析a+b=c;
String addstring="";
for(int i=0;i<item.length();i++){
if(MyUtil.isSignalDivider(item.charAt(i)+"")){//如果是单分隔符
System.out.println(item.charAt(i));
addstring="";
continue;
}
addstring=addstring+item.charAt(i);
if(MyUtil.isDoubleDivider(addstring)){//判断是不是双分隔符
System.out.println(item.charAt(i));
addstring="";
continue;
}
if(item.charAt(i+1)==';'){
if(MyUtil.isNumber(addstring)){
System.out.println("数字:"+addstring);
}else {
System.out.println("变量:"+addstring);
} System.out.println(";");
}
}
} }
} } public static String getInputString() {
System.out.println("请输入一段代码,并以最后一行为end结束");
Scanner scanner = new Scanner(System.in);
String firstLine = scanner.nextLine();
StringBuffer ss = new StringBuffer(firstLine+" ");
while (!firstLine.equals("end")) {
firstLine = scanner.nextLine();
ss.append(firstLine+" ");
}
scanner.close();
System.out.println("读取的是"+ss.toString());
return ss.toString().replace("end", ""); }
}

【编译原理】TEST递归下降演示的更多相关文章

  1. 编译原理-递归下降分析法 c程序部分的分析

    实验三 语法分析程序实验 专业 商软2班   姓名 黄仲浩  学号 201506110166 一. 实验目的      编制一个部分文法分析程序. 二. 实验内容和要求 输入:源程序字符串 输出:正确 ...

  2. 编译原理 #02# 简易递归下降分析程序(js实现)

    // 实验存档 截图: 代码: <!DOCTYPE html> <html> <head> <meta charset="UTF-8"&g ...

  3. 编译原理之LL(1)文法的判断,递归下降分析程序

    1. 文法 G(S): (1)S -> AB (2)A ->Da|ε (3)B -> cC (4)C -> aADC |ε (5)D -> b|ε 验证文法 G(S)是不 ...

  4. 编译原理:LL(1)文法的判断,递归下降分析程序

    1. 文法 G(S): (1)S -> AB (2)A ->Da|ε (3)B -> cC (4)C -> aADC |ε (5)D -> b|ε 验证文法 G(S)是不 ...

  5. Atitit 表达式原理 语法分析 原理与实践 解析java的dsl  递归下降是现阶段主流的语法分析方法

    Atitit 表达式原理 语法分析 原理与实践 解析java的dsl  递归下降是现阶段主流的语法分析方法 于是我们可以把上面的语法改写成如下形式:1 合并前缀1 语法分析有自上而下和自下而上两种分析 ...

  6. Stanford公开课《编译原理》学习笔记(2)递归下降法

    目录 一. Parse阶段 CFG Recursive Descent(递归下降遍历) 二. 递归下降遍历 2.1 预备知识 2.2 多行语句的处理思路 2.3 简易的文法定义 2.4 文法产生式的代 ...

  7. 跟vczh看实例学编译原理——三:Tinymoe与无歧义语法分析

    文章中引用的代码均来自https://github.com/vczh/tinymoe.   看了前面的三篇文章,大家应该基本对Tinymoe的代码有一个初步的感觉了.在正确分析"print ...

  8. Compiler Theory(编译原理)、词法/语法/AST/中间代码优化在Webshell检测上的应用

    catalog . 引论 . 构建一个编译器的相关科学 . 程序设计语言基础 . 一个简单的语法制导翻译器 . 简单表达式的翻译器(源代码示例) . 词法分析 . 生成中间代码 . 词法分析器的实现 ...

  9. 【编译原理】语法分析LL(1)分析法的FIRST和FOLLOW集

    近来复习编译原理,语法分析中的自上而下LL(1)分析法,需要构造求出一个文法的FIRST和FOLLOW集,然后构造分析表,利用分析表+一个栈来做自上而下的语法分析(递归下降/预测分析),可是这个FIR ...

随机推荐

  1. SQL Server 常用的数据类型

    1. 字符串数据类型    char        此数据类型可存储1~8000个定长字符串,字符串长度在创建时指定:如未指定,默认为char(1).每个字符占用1byte存储空间.    nchar ...

  2. 13、FrameRely

    Frame Relay 美国国家标准化协会(American National Standard Institute,简称ANSI)国际电信联盟远程通信标准化组 ITU-T 1.是由ITU和ANSI制 ...

  3. 优雅地关闭worker进程

    关闭nginx两种方式 nginx -s stop  立即停止nginx进程  nginx -s quit 优雅地关闭worker进程 开始优雅的关闭worker进程后 01设置定时器 worker_ ...

  4. 搭建一个V 2ray的方法

    VPS构建VPN教程 (由于博客限制有些敏感词 V 2ray中间会打空格或者(删掉我)图片中的敏感词进行了马赛克处理) 关于自建VPN翻墙教程,此处是利用V 2 ray的一个VPS搭建VPN教程.便于 ...

  5. HDU_1864_01背包

    http://acm.hdu.edu.cn/showproblem.php?pid=1864 题目好像是输入的数据都是两位小数,先统计能报销的发票,然后把小数*100变成成熟就是01背包问题了. #i ...

  6. codeforces 1020 C Elections(枚举+贪心)

    题意: 有 n个人,m个党派,第i个人开始想把票投给党派pi,而如果想让他改变他的想法需要花费ci元.你现在是党派1,问你最少花多少钱使得你的党派得票数大于其它任意党派. n,m<3000 思路 ...

  7. UNIX读书笔记----UNIX基础知识

    UNIX体系结构: 从严格意义上讲,可将操作系统定义为一种软件,它控制计算机硬件资源,提供程序运行环境.我们通常将这种软件称为内核(Kernel),因为他相对较小,而且位于环境的核心.图片显示了UNI ...

  8. EF core (code first) 通过自定义 Migration History 实现多租户使用同一数据库时更新数据库结构

    前言 写这篇文章的原因,其实由于我写EF core 实现多租户的时候,遇到的问题. 具体文章的链接: Asp.net core下利用EF core实现从数据实现多租户(1) Asp.net core下 ...

  9. [Redis-CentOS7]Redis集合操作(四)

    SADD 集合添加 127.0.0.1:6379> SADD bbs discuz.net (integer) 1 127.0.0.1:6379> SADD bbs "tiany ...

  10. Flutter Widgets 之 FutureBuilder

    注意:无特殊说明,Flutter版本及Dart版本如下: Flutter版本: 1.12.13+hotfix.5 Dart版本: 2.7.0 展示异步任务状态 当有一个Future(异步)任务需要展示 ...