亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? optimizer.java.svn-base

?? 北航編譯原理課程設(shè)計(jì)成果——一個(gè)擴(kuò)充的C0文法編譯器
?? SVN-BASE
字號(hào):
package cn.edu.buaa.scse.liyi.compile.tools;

import java.io.File;
import java.util.LinkedList;
import java.util.TreeMap;

import cn.edu.buaa.scse.liyi.compile.types.DataFlow;
import cn.edu.buaa.scse.liyi.compile.types.Function;
import cn.edu.buaa.scse.liyi.compile.types.Quaternion;

/**
 * 
 * @author liyi
 */
public class Optimizer
{
	private LinkedList<Function> funcList=null;
	
	/**
	 * 中間代碼優(yōu)化器構(gòu)造方法
	 * @param funcList
	 */
	public Optimizer(LinkedList<Function> funcList)
	{
		this.funcList=new LinkedList<Function>(funcList);
	}

	public void setFuncList(LinkedList<Function> funcList)
	{
		this.funcList=funcList;
	}
	public LinkedList<Function> getFuncList()
	{
		return funcList;
	}
	
	//判斷一個(gè)字符串的內(nèi)容是否為一個(gè)整數(shù)
	private boolean isInteger(String str)
	{
		try
		{
			Integer.parseInt(str);
		}
		catch(Exception e)
		{
			return false;
		}
		return true;
	}
	
	/**
	 * 基本塊內(nèi)部的公共子表達(dá)式刪除
	 */
	private void deleteCommonSubexpression()
	{
		//常量合并,復(fù)制傳播,公共子表達(dá)式刪除
		for(int n=0;n<funcList.size();n++)
		{
			Function curfunc=funcList.get(n);
			LinkedList<Quaternion> quaterList=new LinkedList<Quaternion>();
			
			for(int i=0;i<curfunc.getQuaterList().size();i++)
			{
				Quaternion quater=curfunc.getQuaterList().get(i);
				if(quater==null)
					continue;
				else if((quater.getOperator()>=Yacc.ADD)&&(quater.getOperator()<=Yacc.DIV))
				{
					if(isInteger(quater.getOperend1())&&isInteger(quater.getOperend2()))
					{
						Integer result=0;
						int operend1=Integer.parseInt(quater.getOperend1());
						int operend2=Integer.parseInt(quater.getOperend2());
						
						switch (quater.getOperator())
						{
							case Yacc.ADD:
								result=new Integer(operend1+operend2);
								break;
							case Yacc.SUB:
								result=new Integer(operend1-operend2);
								break;
							case Yacc.MUL:
								result=new Integer(operend1*operend2);
								break;
							case Yacc.DIV:
								result=new Integer(operend1/operend2);
								break;
						}
						curfunc.getQuaterList().set(i,null);
						for(int j=i+1;j<curfunc.getQuaterList().size();j++)
						{
							Quaternion reg0=curfunc.getQuaterList().get(j);
							if(reg0==null)
								continue;
							else if(((reg0.getOperator()>=Yacc.ADD)&&(reg0.getOperator()<=Yacc.DIV)))
							{
								if(reg0.getOperend1().equals(quater.getResult()))
								{
									reg0.setOperend1(result.toString());
									curfunc.getQuaterList().set(j,reg0);
								}
								else if(reg0.getOperend2().equals(quater.getResult()))
								{
									reg0.setOperend2(result.toString());
									curfunc.getQuaterList().set(j,reg0);
								}
							}
							else if((reg0.getOperator()==Yacc.MOV)&&(reg0.getOperend1().equals(quater.getResult())))
							{
								reg0.setOperend1(result.toString());
								curfunc.getQuaterList().set(j,reg0);
							}
							else
								break;
						}
					}
					else
					{
						for(int j=i+1;j<curfunc.getQuaterList().size();j++)
						{
							Quaternion reg1=curfunc.getQuaterList().get(j);
							if(reg1==null)
								continue;
							else if(((reg1.getOperator()>=Yacc.ADD)&&(reg1.getOperator()<=Yacc.DIV)))
							{
								if(quater.equivalents(reg1))
								{
									curfunc.getQuaterList().set(j,null);
									
									for(int k=j+1;k<curfunc.getQuaterList().size();k++)
									{
										Quaternion reg2=curfunc.getQuaterList().get(k);
										if(reg2==null)
											continue;
										else if(((reg2.getOperator()>=Yacc.ADD)&&(reg2.getOperator()<=Yacc.DIV)))
										{
											if(reg2.getOperend1().equals(reg1.getResult()))
											{
												reg2.setOperend1(quater.getResult());
												curfunc.getQuaterList().set(k,reg2);
											}
											else if(reg2.getOperend2().equals(reg1.getResult()))
											{
												reg2.setOperend2(quater.getResult());
												curfunc.getQuaterList().set(k,reg2);
											}
										}
										else if((reg2.getOperator()==Yacc.MOV)&&(reg2.getOperend1().equals(reg1.getResult())))
										{
											reg2.setOperend1(quater.getResult());
											curfunc.getQuaterList().set(k,reg2);
										}
										else
											break;
									}
								}
							}
							else if((reg1.getOperator()==Yacc.MOV)&&(reg1.getResult().equals(quater.getOperend1())||reg1.getResult().equals(quater.getOperend2())))
							{
								break;
							}
							else if((reg1.getOperator()==Yacc.SCANF)&&(reg1.getOperend1().equals(quater.getOperend1())||reg1.getOperend1().equals(quater.getOperend2())))
							{
								break;
							}
						}
					}
				}
			}
			
			for(Quaternion quater:curfunc.getQuaterList())
			{
				if(quater!=null)
				{
					quaterList.add(quater);
				}
			}
			
			curfunc.setQuaterList(quaterList);
			funcList.set(n,curfunc);
		}
		
		//冗余的賦值操作刪除
		for(int i=0;i<funcList.size();i++)
		{
			Function func=funcList.get(i);
			LinkedList<Quaternion> quaterList=func.getQuaterList();
			TreeMap<String,Integer> vmap=new TreeMap<String,Integer>();
			
			for(int j=0;j<quaterList.size();j++)
			{
				Quaternion quater=quaterList.get(j);
				if((quater.getOperator()>=Yacc.ADD)&&(quater.getOperator()<=Yacc.DIV)&&quater.getResult().startsWith("@"))
				{
					Quaternion reg1=quaterList.get(j+1);
					if((reg1.getOperator()==Yacc.MOV)&&reg1.getOperend1().equals(quater.getResult()))
					{
						boolean flag=false;
						for(int k=j+2;k<quaterList.size();k++)
						{
							Quaternion reg2=quaterList.get(k);
							if(quater.getResult().equals(reg2.getOperend1())||quater.getResult().equals(reg2.getOperend2()))
							{
								flag=true;
								break;
							}
						}
						if(!flag)
						{
							funcList.get(i).getQuaterList().get(j).setResult(reg1.getResult());
							funcList.get(i).getQuaterList().remove(j+1);
						}
					}
				}
			}
			
			int len=1;
			
			for(String var:funcList.get(i).getVar())
			{
				vmap.put(var,len*4);
				len++;
			}
			
			for(Quaternion quater:quaterList)
			{
				if(quater!=null)
				{
					if(quater.getResult()!=null&&quater.getResult().startsWith("@"))
					{
						vmap.put(quater.getResult(),len*4);
						len++;
					}
				}
			}
			
			funcList.get(i).setVmap(vmap);
		}
	}
	
	/**
	 * 無(wú)用代碼刪除
	 */
	private void deleteUselessCode()
	{
		boolean flag=false;
		boolean turn=true;
		
		while(turn)
		{
			int i=0;
			turn=false;
			for(Function fcheck=funcList.get(i);i<funcList.size();fcheck=funcList.get(i))
			{
				flag=false;
				if(fcheck.getName().equals("main"))
					break;
				for(Function func:funcList)
				{
					if(fcheck.getName().equals(func.getName()))
						continue;
					else
					{
						for(Quaternion quater:func.getQuaterList())
						{
							if(quater.getOperator()==Yacc.CALL&&quater.getOperend1().equals(fcheck.getName()))
							{
								flag=true;
								break;
							}	
						}
						if(flag)
							break;
					}
				}
				if(!flag)
				{
					funcList.remove(fcheck);
					turn=true;
				}
				else
					i++;
			}
		}
	}
	
	/**
	 * 多種優(yōu)化策略綜合處理
	 */
	public void process()
	{
		deleteUselessCode();
		deleteCommonSubexpression();
	}
	
	public static void main(String argv [])
	{
		File file=new File("D:/test11.txt");
		Lex lex=new Lex(file);
		lex.analyze();
		Yacc yacc=new Yacc(lex.getList());
		yacc.parseProgram();
		Optimizer opti=new Optimizer(yacc.getFuncList());
		opti.deleteCommonSubexpression();
		for(Function func:opti.getFuncList())
		{
			DataFlow flow=new DataFlow(func.getQuaterList());
			flow.buidDiagram();
			System.out.println("四元式");
			Quaternion quater;
			while((quater=flow.nextTrank())!=null)
				System.out.println(quater);
		}
	}
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久电影一区二区三区| 日韩亚洲欧美综合| 亚洲欧洲精品一区二区精品久久久| 国产又黄又大久久| 国产日韩欧美高清在线| 成人av免费在线观看| 亚洲美女视频一区| 欧美精品久久久久久久久老牛影院| 美女视频网站黄色亚洲| 国产女主播在线一区二区| 99久久精品免费看国产免费软件| 一区二区日韩电影| 欧美成人a∨高清免费观看| 国产91丝袜在线观看| 亚洲丝袜另类动漫二区| 欧美精品第1页| 狠狠色丁香久久婷婷综| 亚洲三级免费电影| 欧美乱熟臀69xxxxxx| 国产成人综合亚洲网站| 亚洲蜜桃精久久久久久久| 欧美精品高清视频| 成人福利视频网站| 性久久久久久久| 欧美国产精品一区二区| 在线日韩国产精品| 色国产综合视频| 九九国产精品视频| 亚洲精品成人天堂一二三| 在线综合视频播放| 成人免费看片app下载| 亚洲成人一区二区| 国产精品视频免费| 欧美日韩中文另类| 国产曰批免费观看久久久| 夜夜精品浪潮av一区二区三区| 精品人伦一区二区色婷婷| 一本一道久久a久久精品| 蜜桃av一区二区在线观看| 亚洲人成亚洲人成在线观看图片 | 中文字幕字幕中文在线中不卡视频| 欧美高清精品3d| 91丨九色丨国产丨porny| 久久er精品视频| 一区二区视频在线看| 久久久久久久久蜜桃| 欧美日韩一区二区三区免费看| 国产成都精品91一区二区三| 日韩成人免费看| 亚洲最新在线观看| 国产精品第一页第二页第三页| 精品福利二区三区| 欧美放荡的少妇| 欧美亚洲自拍偷拍| 99免费精品在线| 国产一区在线精品| 男女男精品视频| 亚洲va在线va天堂| 亚洲精品一卡二卡| 亚洲欧美国产高清| 国产精品久久久久久久久久免费看 | 久久久久久麻豆| 91精品国产福利| 欧美日韩国产一二三| 色婷婷av一区二区三区大白胸| 丁香婷婷综合激情五月色| 国产一区在线不卡| 国产一区二区剧情av在线| 久久精品国产亚洲高清剧情介绍| 丝瓜av网站精品一区二区| 亚洲高清免费一级二级三级| 一区二区三区四区精品在线视频| 亚洲欧洲美洲综合色网| 国产精品女主播在线观看| 中文字幕免费不卡| 中文字幕一区二区三区精华液 | 国产成人精品午夜视频免费| 国产在线不卡视频| 国产精品1区2区3区| 岛国精品在线观看| 成人18视频日本| 91视频观看视频| 色av成人天堂桃色av| 精品视频999| 欧美一区二区在线免费观看| 日韩欧美在线一区二区三区| 欧美电影免费观看高清完整版在线 | 亚洲日本一区二区三区| 国产精品久久久久久久第一福利| 中文字幕免费观看一区| 国产精品久久久久久亚洲毛片| 一区二区中文视频| 亚洲午夜免费福利视频| 日本午夜一本久久久综合| 久久91精品久久久久久秒播 | 国产成人免费av在线| 成人在线综合网| 在线精品视频免费观看| 91精品蜜臀在线一区尤物| 日韩三级伦理片妻子的秘密按摩| 欧美va亚洲va在线观看蝴蝶网| 久久精子c满五个校花| 亚洲人快播电影网| 日本一区中文字幕| 国产精品一区一区三区| 91在线国内视频| 91精品国产综合久久久久久漫画| 久久久精品天堂| 亚洲欧美成人一区二区三区| 三级精品在线观看| 久久久亚洲精华液精华液精华液| 精品一区二区久久久| 国产成人av网站| 色狠狠色狠狠综合| 日韩女优av电影在线观看| 国产日韩欧美一区二区三区乱码| 一区二区在线观看免费视频播放 | 国产精品女同一区二区三区| 樱花草国产18久久久久| 国产主播一区二区| 欧美亚洲国产bt| 欧美激情一区在线观看| 成人av电影在线观看| 欧美精三区欧美精三区| 亚洲国产精品激情在线观看| 午夜欧美电影在线观看| 成人夜色视频网站在线观看| 91精品在线一区二区| 国产精品久久久久影院色老大| 日韩黄色一级片| 99r国产精品| 久久蜜桃av一区二区天堂| 亚洲一区二区四区蜜桃| 成人动漫一区二区| 精品国产髙清在线看国产毛片| 欧美精品久久一区二区三区| 一本在线高清不卡dvd| 欧美tk丨vk视频| 亚洲一区二区影院| 国产不卡在线视频| 精品sm在线观看| 日韩福利电影在线| 欧美亚洲动漫另类| 中文字幕亚洲电影| 国产成人精品影视| 精品少妇一区二区三区免费观看| 亚洲在线视频免费观看| www.亚洲精品| 欧美极品xxx| 国产成人午夜片在线观看高清观看| 91精品久久久久久久久99蜜臂| 亚洲资源中文字幕| 色欧美片视频在线观看| 亚洲丝袜自拍清纯另类| av日韩在线网站| 国产精品福利av| 成人av在线电影| 国产欧美1区2区3区| 国产福利一区二区三区视频在线 | 亚洲不卡av一区二区三区| 国产成人欧美日韩在线电影 | 国产亚洲欧美一级| 精久久久久久久久久久| 日韩一卡二卡三卡| 久久精品国产精品青草| 7777精品伊人久久久大香线蕉 | 不卡的av中国片| 欧美国产禁国产网站cc| 高清成人免费视频| 欧美高清在线一区| 成人av在线看| 亚洲黄网站在线观看| 欧亚一区二区三区| av一二三不卡影片| 中文字幕一区不卡| 成人18视频日本| 亚洲综合激情小说| 69堂亚洲精品首页| 精品一区二区三区av| 久久久久久99久久久精品网站| 国产高清在线精品| 亚洲视频在线一区观看| 成人免费毛片a| 亚洲女爱视频在线| 欧美三级资源在线| 蜜臀国产一区二区三区在线播放 | 亚洲成av人片一区二区三区| 欧美三级视频在线| 久久精品久久综合| 中文字幕高清一区| 91成人免费电影| 美国毛片一区二区三区| 久久久久久亚洲综合| 91久久国产综合久久| 日韩中文字幕亚洲一区二区va在线| 欧美不卡视频一区| 91亚洲国产成人精品一区二区三 | 69久久夜色精品国产69蝌蚪网| 精品在线播放免费| 亚洲视频免费看|