编译原理——变量声明语句(七)

原创 2012年03月30日 22:19:20

Action动作表。

代码:

Action.java

package per.eyuan.util;

public class Action {
	/*
	 * SLR的action表,接受传递过来的状态和终结符,
	 * 返回action表中对应的动作r(归约)或者s(移进),
	 * Syntax,根据动作做相应的操作。
	 */
	private String action[][]=new String[10][6];
	String statu;//状态
	String vt;//终结符
	int rol;//行,action表中的行,代表状态,
	int col;//列,action表中的列,代表终结符,顺序为0"id",1"int",2"float",3",",4";",5"#"
	
	public Action() {
		super();
		init();
	}
	public void init(){
		for(int i=0;i<action.length;i++){
			for(int j=0;j<action[i].length;j++)
				action[i][j]=new String("err");
		}
		action[0][1]="s3";
		action[0][2]="s4";
		action[1][5]="acc";
		action[2][3]="s6";
		action[2][4]="s5";
		action[3][0]="s7";
		action[4][0]="s8";
		action[5][5]="r1";
		action[6][0]="s9";
		action[7][3]="r2";
		action[7][4]="r2";
		action[8][3]="r3";
		action[8][4]="r3";
		action[9][3]="r4";
		action[9][4]="r4";
	}
	public void getCol(){
		//获取终结符对应的列值
		if(vt.equals("id"))
			col=0;
		else if(vt.equals("int"))
			col=1;
		else if(vt.equals("float"))
			col=2;
		else if(vt.equals(","))
			col=3;
		else if(vt.equals(";"))
			col=4;
		else if(vt.equals("#"))
			col=5;
	}
	public void getRol(){
		//获取状态对应的行值
		rol=Integer.parseInt(statu);
	}
	public void setTable(String s,String v){
		//Syntax调用该函数,传递状态和终结符
		this.statu=s;
		this.vt=v;
		this.getCol();
		this.getRol();
		//System.out.println("获取的状态和终结符是"+s+"-"+v+"对应的行列为"+rol+"-"+col);
	}
	public String getAction(){
		//Syntax调用该函数,获取动作
		//System.out.println("返回的动作是"+this.action[rol][col]);
		return this.action[rol][col];

	}


}

编译原理——变量声明语句(十三)

四元式。 代码: FourItem.java: package per.eyuan.util; public class FourItem { String op; String ...
  • EYUANatQQdotCOM
  • EYUANatQQdotCOM
  • 2012-03-30 22:27:39
  • 320

编译原理——变量声明语句(十五)

栈结构。 代码: MyStack.java package per.eyuan.util; public class MyStack { //用来存储状态,符号,语义等信息 //字...
  • EYUANatQQdotCOM
  • EYUANatQQdotCOM
  • 2012-03-30 22:30:30
  • 227

编译原理课程设计

  • 2012年07月12日 16:18
  • 33KB
  • 下载

编译原理——变量声明语句(十)

常数表。 代码: Constant.java package per.eyuan.util; //常数表 public class Constant { String key="num"...
  • EYUANatQQdotCOM
  • EYUANatQQdotCOM
  • 2012-03-30 22:23:34
  • 331

编译原理——变量声明语句(四)

语法分析。 代码: Syntax.java package per.eyuan.compile; import per.eyuan.util.Action; import per.eyu...
  • EYUANatQQdotCOM
  • EYUANatQQdotCOM
  • 2012-03-30 22:12:55
  • 297

编译原理——变量声明语句(三)

词法分析: 代码: Lexical.java: package per.eyuan.compile; import per.eyuan.util.*; public class Le...
  • EYUANatQQdotCOM
  • EYUANatQQdotCOM
  • 2012-03-30 22:11:36
  • 417

编译原理——变量声明语句(十四)

四元式栈。 代码: FourItemStack.java: package per.eyuan.util; public class FourItemStack { private i...
  • EYUANatQQdotCOM
  • EYUANatQQdotCOM
  • 2012-03-30 22:29:03
  • 276

编译原理——变量声明语句(二)

代码: IO.java package per.eyuan.compile; import java.io.File; import java.io.IOException; impor...
  • EYUANatQQdotCOM
  • EYUANatQQdotCOM
  • 2012-03-30 22:08:25
  • 227

编译原理——变量声明语句(八)

标识符。 代码: Id.java package per.eyuan.util; //待分析语句int a,b; public class Id { final String id="i...
  • EYUANatQQdotCOM
  • EYUANatQQdotCOM
  • 2012-03-30 22:21:14
  • 216

编译原理——变量声明语句(十二)

二元式。 代码: TwoItem.java: package per.eyuan.util; public class TwoItem { String item1;//类别id,nu...
  • EYUANatQQdotCOM
  • EYUANatQQdotCOM
  • 2012-03-30 22:26:44
  • 202
收藏助手
不良信息举报
您举报文章:编译原理——变量声明语句(七)
举报原因:
原因补充:

(最多只允许输入30个字)