Micro语言的词法分析程序 Java代码

本实验报告详细介绍了如何设计和实现Micro语言的词法分析器,使用Java编程。内容包括Micro语言的定义、词法规则、状态转换图、伪代码以及在处理词法分析时遇到的问题和解决方案,如在begin和end后加空格来正确识别语句。
摘要由CSDN通过智能技术生成
import java.io.BufferedReader;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;

public class Analyzer {

	private String []keyWords = { "int", "begin","end", "read", "write"}; // 关键字数组
	private char []operators = { '=', '+', '-' }; // 运算符数组
	private char []separators = { ',', ';', '(', ')' }; // 分隔符数组
	private String fileSrcName; // 源程序名
	private static StringBuffer buffer = new StringBuffer(); // 缓冲区
	private char ch; // 字符变量,存放最新读进的源程序字符
	private static int i = 0;
	private static int ketType;// 作返回值,用于调用不同的打印的方法
	private String strToken; // 字符数组,存放构成单词符号的字符串

	public Analyzer() {
	}

	public Analyzer(String fileSrcName) {
		this.fileSrcName = fileSrcName;
	}

	/**
	 * 将下一个输入字符读到ch中,搜索指示器前移一个字符 比如字符串的长度是6 但是每个字符的下标是从0开始计算 0 1 2 3 4 5
	 * 所以charAt(i)中的i最大是字符串长度-1. 你在do while循环里有个i++,i 如果等于5的时候,i++后i=6在charAt(i)就明显越界了
	 */
	
	public void getChar() {
		if (i < buffer.length()) {// i<6
			ch = buffer.charAt(i);
			if(i!=buffer.length()-1){// i!=5 i才能++ 这一步很关键的!
				i++;
			}
		}
	}

	/**
	 * 检查ch中的字符是否为空白,若是则调用getChar() 直至ch中进入一个非空白字符
	 */
	
	public void getBc() {
		while (Character.isSpaceChar(ch))
			getChar();
	}

	/**
	 * 将ch连接到strToken之后
	 */
	public void concat() {
		strToken += ch;
	}

	/**
	 * 判断字符是否为字母
	 */
	boolean isLetter() {
		return Character.isLetter(ch);
	}

	/**
	 * 判断字符是否为数字
	 */
	boolean isDigit() {
		return Character.isDigit(ch);
	}

	/**
	 * 将搜索指示器回调一个字符位置,将ch值为空白字
	 */
	public void retract() {
		i--;
		ch =' ';
	}

	/**
	 * 判断单词是否为关键字 
	 */
	public int isKeyWord() {
		ketType = -1;
		for (int i = 0; i < keyWords.length; i++) {
			if (keyWords[i].equals(strToken))
				ketType = i;
		}
		return ketType;
	}
	
	


	/**
	 * 判断是否为运算符 [6,9) 678
	 */
	public int isOperator() {
		ketType = -1;
		for (int i = 0; i < operators.length; i++) {
			// 例如operators[]有 = + -,那么operators[1] = ‘+’
			// 如果调用此方法判断是否为+,则当前i遍历的0、1
			// 返回的种别码ketType为1+5=6
			// 符合一开始设定的种别码表
			if (ch == operators[i])
				ketType = i + 5;
		}
		return ketType;
	}

	/**
	 * 判断是否为分隔符8 9 10 11
	 */
	public int isSeparators() {
		ketType = -1;
		for (int i = 0; i < separators.length; i++) {
			if (ch == separators[i])
				ketType = i + 8;
		}
		return ketType;
	}

	/**
	 * 打印关键字strToken
	 */
	public void insertKeyWords(String strToken) {
		System.out.println("(" + ketType + "," + strToken + ")");
	}

	/**
	 * 打印运算符ch
	 * 
	 */
	pu
  • 1
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值