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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? optimizer.java

?? 北航編譯原理課程設(shè)計成果——一個擴(kuò)充的C0文法編譯器
?? JAVA
字號:
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;
	}
	
	//判斷一個字符串的內(nèi)容是否為一個整數(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);
		}
	}
	
	/**
	 * 無用代碼刪除
	 */
	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);
		}
	}
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
精品久久久久久久久久久久包黑料| 裸体健美xxxx欧美裸体表演| 成人av影视在线观看| 国产亚洲人成网站| 粗大黑人巨茎大战欧美成人| 国产精品成人免费| 在线免费精品视频| 日韩激情视频在线观看| 欧美一区二区黄色| 国产一区二区0| 亚洲国产高清不卡| 91成人网在线| 免费观看91视频大全| 久久久久久久一区| av不卡在线播放| 夜夜揉揉日日人人青青一国产精品| 欧美久久久一区| 韩国精品在线观看| 亚洲天堂成人网| 7777精品伊人久久久大香线蕉| 国产乱子伦一区二区三区国色天香| 亚洲国产激情av| 欧美高清视频不卡网| 国产精品白丝jk黑袜喷水| 亚洲黄色性网站| 精品国产伦一区二区三区观看体验 | 一个色综合av| 精品久久久久久综合日本欧美 | 日韩和欧美一区二区三区| 久久嫩草精品久久久久| 色综合久久99| 久久黄色级2电影| 亚洲乱码国产乱码精品精可以看 | 久久99久久久欧美国产| 国产精品二区一区二区aⅴ污介绍| 欧美视频完全免费看| 狠狠色狠狠色综合| 亚洲国产精品精华液网站| 久久久精品免费观看| 正在播放亚洲一区| 99久久99精品久久久久久| 另类专区欧美蜜桃臀第一页| 亚洲人成网站色在线观看| 欧美成人精品3d动漫h| 欧美亚洲一区二区在线| 国产 日韩 欧美大片| 捆绑调教美女网站视频一区| 亚洲精品免费看| 国产日韩欧美a| 精品噜噜噜噜久久久久久久久试看 | 欧美老年两性高潮| 99久久99精品久久久久久 | 日本不卡视频一二三区| 亚洲精品高清在线| 国产精品拍天天在线| 2023国产精品视频| 日韩西西人体444www| 欧美日韩一区视频| 一本色道久久综合亚洲aⅴ蜜桃| 国产乱码精品一区二区三 | 国产资源在线一区| 免费成人小视频| 无码av免费一区二区三区试看 | 国产高清精品久久久久| 伦理电影国产精品| 日韩av在线播放中文字幕| 一个色在线综合| 一个色妞综合视频在线观看| 国产精品久久久久aaaa樱花 | 国产精品超碰97尤物18| 久久婷婷色综合| 久久综合狠狠综合久久激情| 日韩亚洲欧美一区| 在线成人av影院| 欧美疯狂做受xxxx富婆| 在线播放视频一区| 欧美久久久影院| 欧美一区二区在线看| 欧美精品一区二区三区在线 | 日韩午夜精品视频| 欧美日本在线一区| 欧美三级在线播放| 欧美日韩在线播放一区| 欧美伊人久久久久久午夜久久久久| 一本大道av一区二区在线播放| 99热这里都是精品| 色国产精品一区在线观看| 欧美在线视频不卡| 欧美老年两性高潮| 日韩精品影音先锋| 久久久高清一区二区三区| 国产视频在线观看一区二区三区| 国产日产欧美一区| 亚洲欧洲性图库| 一区二区三区四区视频精品免费 | 精品三级在线看| 久久久久99精品国产片| 亚洲欧洲精品一区二区三区不卡| 亚洲人成小说网站色在线 | 欧美成人精品二区三区99精品| 精品国内片67194| 国产亚洲人成网站| 玉足女爽爽91| 久久成人免费电影| www.欧美精品一二区| 欧美色倩网站大全免费| 精品国产免费一区二区三区四区 | 欧美性生活一区| 日韩一区二区视频在线观看| 久久久青草青青国产亚洲免观| 国产精品美女久久久久久久久 | 中文字幕一区视频| 亚洲va欧美va人人爽| 国产一区二区三区日韩| jizzjizzjizz欧美| 欧美一区日本一区韩国一区| 亚洲国产精品精华液2区45| 一区二区三区在线视频观看58| 美国三级日本三级久久99| 大白屁股一区二区视频| 91精品免费观看| 日本一区二区三区国色天香| 亚洲线精品一区二区三区| 国产一区免费电影| 欧美在线高清视频| 久久精品亚洲精品国产欧美kt∨| 亚洲黄色片在线观看| 国产精品一区二区不卡| 欧美日韩亚洲综合在线 | 成人免费黄色大片| 精品视频资源站| 亚洲欧洲av一区二区三区久久| 七七婷婷婷婷精品国产| 成人avav在线| 精品粉嫩超白一线天av| 亚洲一区二区三区中文字幕| 国产成人在线电影| 日韩欧美一区二区三区在线| 亚洲精品成人天堂一二三| 国产黄人亚洲片| 日韩午夜av一区| 亚洲国产cao| 色呦呦国产精品| 中文无字幕一区二区三区| 免费av网站大全久久| 欧美日韩在线播放三区四区| 中文字幕一区视频| 夫妻av一区二区| 26uuu精品一区二区| 日本亚洲三级在线| 欧美日韩国产精品自在自线| 中文字幕一区二区不卡| 成人综合婷婷国产精品久久免费| 日韩午夜在线播放| 日韩av电影免费观看高清完整版 | 亚洲成人一区在线| 91黄色免费观看| 一区在线观看免费| 99在线精品观看| 国产精品人妖ts系列视频| 懂色av一区二区在线播放| 久久亚洲私人国产精品va媚药| 免费成人av在线| 精品欧美乱码久久久久久| 美女一区二区在线观看| 91精品一区二区三区在线观看| 五月婷婷欧美视频| 欧美精品一级二级三级| 图片区小说区国产精品视频| 欧美丝袜丝交足nylons图片| 亚洲成人精品在线观看| 欧美日韩国产大片| 奇米亚洲午夜久久精品| 精品日韩一区二区| 国产精品综合在线视频| 亚洲国产成人自拍| 91蜜桃传媒精品久久久一区二区| 亚洲欧美在线aaa| 97久久精品人人澡人人爽| 17c精品麻豆一区二区免费| 91麻豆精东视频| 亚洲国产精品精华液网站| 欧美日本在线看| 精品一区二区免费| 国产色一区二区| 99久久久免费精品国产一区二区| 国产精品乱人伦| 欧美在线免费观看亚洲| 日韩成人一区二区| 久久综合给合久久狠狠狠97色69| 高清不卡一二三区| 亚洲免费观看高清完整版在线观看| 91在线观看成人| 偷窥少妇高潮呻吟av久久免费| 91精品国产欧美一区二区18| 国产精品一区二区在线观看不卡| ...xxx性欧美| 91精品免费在线观看| 成人免费视频视频在线观看免费| 亚洲综合偷拍欧美一区色|