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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? util.cpp

?? 編譯原理學習使用的代碼 內容有從詞法分析到中間代碼生成的代碼 并且含有注釋
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
			/*從下一條語句開始,進入一個新的基本塊*/
			 if (code->next!= NULL)
			 { code = code->next;
			   baseBlock[blocknum++] =code;
			 }
			 break;
		/*變參傳遞*/
		case VARACT: 
			 /*找到對應的過程調用語句,作為本基本塊的結束*/
			 code = code->next;
			 while (code->codeR.codekind != CALL)
				 code = code->next;
			 /*從下一條語句開始,進入一個新的基本塊*/
			 if (code->next!= NULL)
			 { code = code->next;
			   baseBlock[blocknum++] =code;
			 }
			 
        default : break;
	   }
       code = code->next;
	}
	return(blocknum);
}
 
/********************************************************/
/* 函數名  PrintBaseBlock								*/
/* 功  能  打印基本塊第一條代碼,以顯示基本塊的劃分		*/
/* 說  明												*/
/********************************************************/  
void PrintBaseBlock(int  blocknum)
{
	for (int i=0;i<blocknum ;i++)
	{ PrintOneCode(baseBlock[i]);
      fprintf(listing,"\n");
	}
}


/**************用于公共表達式優化*****************/
/********************************************************/
/* 函數名  printValuNum									*/
/* 功  能  輸出值編碼表									*/
/* 說  明												*/
/********************************************************/  
void   printValuNum()
{ 
	fprintf(listing,"\n************Value  Num **************\n");

	ValuNum  *Item = valuNumT;
	while (Item!=NULL)
	{   
		PrintContent(Item->arg);
		fprintf(listing,"  ");
		if (Item->access == indir )
		{   fprintf(listing ,"(");
			fprintf(listing,"%d",Item->codeInfo.twoCode.valuecode);
			fprintf(listing," , ");
			fprintf(listing,"%d",Item->codeInfo.twoCode.addrcode);
		    fprintf(listing,")");
		}
       else  fprintf(listing,"%d",Item->codeInfo.valueCode);
       
	   fprintf(listing,"\n");
	   Item = Item->next;
	}
}

/********************************************************/
/* 函數名  printUsableExpr								*/
/* 功  能  輸出可用表達式編碼表							*/
/* 說  明												*/
/********************************************************/  
void   printUsbleExpr()
{
	fprintf(listing,"\n************Usable  Expression**************\n");
	UsableExpr  *Item = usableExprT;
	while (Item!=NULL)
	{ PrintOneCode(Item->code);
	  fprintf(listing, "  :  ");
	  fprintf(listing,"(");
	  fprintf(listing,"%d  ",Item->mirrorC->op1);
	  fprintf(listing,"%d  ",Item->mirrorC->op2);
	  fprintf(listing,"%d  ",Item->mirrorC->result);
	  fprintf(listing,")");
	  
	  fprintf(listing,"\n");
	  Item = Item->next;
	}

}


/********************************************************/
/* 函數名  printTempEqua								*/
/* 功  能  輸出臨時變量等價表							*/
/* 說  明												*/
/********************************************************/  
void   printTempEqua()
{

	fprintf(listing,"\n************Temp  Equa **************\n");

	TempEqua  * Item = tempEquaT;
	while (Item!=NULL)
	{ PrintContent(Item->arg1);
		fprintf(listing,"   ");
		PrintContent(Item->arg2);

		fprintf(listing,"\n");
		Item = Item->next;
  }
}

/*循環信息棧的壓棧實現過程*/
void  PushLoop(LoopInfo  *t)
{
	LoopStack *p = (LoopStack *)malloc (sizeof(LoopStack));
	p->loopInfo = t ;
	p->under=loopTop;
    loopTop = p;
	loopStackEmpty = false;
}

/*循環信息棧的彈棧實現過程*/
LoopInfo *PopLoop()
{     
  LoopStack  *p=NULL;
  LoopInfo   *backpointer = NULL;
  p =loopTop;
  backpointer=p->loopInfo;
  loopTop=loopTop->under;
  free(p);
  if (loopTop==NULL)
	  loopStackEmpty = true;

  return backpointer;
}
 


/***********************************************************/
/***********以下為目標代碼生成時所用的函數******************/
/***********************************************************/


/***********************************************************/
/* 函數名  FindSp                                          */
/* 功  能  找到該變量所在AR的sp                            */
/* 說  明												   */
/***********************************************************/
void findSp(int varlevel)
{
	/*先求該變量層數在AR中的位置,其中varLevel表示變量所在層*/
	emitRM("LDA",ac1,varlevel,displayOff," var process");
	
	/*絕對地址*/
	emitRO("ADD",ac1,ac1,sp," var sp relative address");
    
	/*該變量所在AR的sp地址存在ac1中*/
	emitRM("LD",ac1,0,ac1," var sp");
}

/***********************************************************/
/* 函數名  FindAdd                                         */
/* 功  能  計算基本類型變量、下標變量和域變量的絕對地址    */
/* 說  明  將絕對地址存入ac中		    				   */
/***********************************************************/
void FindAdd(TreeNode * t)
{
	
	int Loc;
	int varLevel;

	fieldChain * fieldMem = NULL;

	if(t!=NULL)
	{
		
		/*得到該變量在符號表中的地址*/
		Loc = t->table[0]->attrIR.More.VarAttr.off;
					
		/*記錄該變量所在層*/
		varLevel = t->table[0]->attrIR.More.VarAttr.level;
				
		/*可能是下標類型或者域類型或者是基本變量類型,把地址取出送入ac*/
						
		/*普通變量*/
		if(t->child[0] == NULL)
		{
			emitRM("LDC",ac,Loc,0," base type var relative address");
		}
		/*數組類型變量*/
		else if(t->attr.ExpAttr.varkind==ArrayMembV)
		{
			/*將數組下標值送入ac中*/
			cGen(t->child[0]);
	
			/*數組下屆存入ac1中*//*attr.ArrayAttr.low*/
			emitRM("LDC",ac1,t->table[0]->attrIR.idtype->More.ArrayAttr.low,0,"array low bound");
	
			/*要用ac減去數組下屆*/
			emitRO("SUB",ac,ac,ac1,"");
				
			/*求出該數組變量的偏移*/
			emitRM("LDA",ac,Loc,ac," array type var relative address");

		}
		/*記錄類型變量*/
		else if(t->attr.ExpAttr.varkind==FieldMembV)
		{
			/*處理域變量的偏移*/
			fieldMem = t->table[0]->attrIR.idtype->More.body;
				
			/*在域表中查找該域變量*/
			while(fieldMem != NULL)
			{
				int result = strcmp(t->child[0]->name[0],fieldMem->id);
				/*如果相等*/
				if(result==FALSE)
					break;
				else
				fieldMem = fieldMem->Next;
			}	 
			/*域變量為基本類型變量*/
			if(t->child[0]->child[0]==NULL)
			{
				emitRM("LDC",ac,Loc,0,"");
				emitRM("LDA",ac,fieldMem->off,ac,"field type var relative address");
				/*此時ac中存放的是相對偏移*/
			}
								
			/*域變量是數組變量的情況*/
			else
			{
				genExp(t->child[0]->child[0]);
				emitRM("LDC",ac1,t->child[0]->attr.ArrayAttr.low,0,"array low");
				/*數組下標減去下屆*/
				emitRO("SUB",ac,ac,ac1,"");
				emitRM("LDA",ac,fieldMem->off,ac,"");
									
				emitRM("LDA",ac,Loc,ac,"");
								
			}/*ac中存儲的是域變量的在當前AR的偏移*/
		}
			
		/*計算該變量的sp*/
		findSp(varLevel);
		/******找到sp*****************/
		  
		/* 計算絕對偏移 */
		emitRO("ADD",ac,ac,ac1," var absolute off");

	}
}



/**************************************************/
/****************釋放指針空間部分******************/
/**************************************************/

void freeDec(TreeNode * p);

void freeStm(TreeNode * p);

void freeExp(TreeNode * t);
/***********************************************************/
/* 函數名  freeTree                                        */
/* 功  能  通過遞歸調用釋放指針空間                        */
/* 說  明                    		    				   */
/***********************************************************/
void freeTree(TreeNode * t)
{
	TreeNode * p = NULL;

	if(t!=NULL)
		free(t->child[0]);
	
	p = t->child[1];
	
	freeDec(p);
				
	p = t->child[2]->child[0];
	
	freeStm(p);

}
/***********************************************************/
/* 函數名  freeDec                                         */
/* 功  能  通過遞歸調用釋放聲明類型指針空間                */
/* 說  明                    		    				   */
/***********************************************************/
void freeDec(TreeNode * p)
{
	TreeNode * p1 = NULL;
	TreeNode * p2 = NULL;
	
	while(p!=NULL)
	{	
		switch(p->nodekind)
		{
			case TypeK:
			case VarK:
				/*p1指向類型聲明節點鏈或者變量聲明節點鏈*/
				p1 = p->child[0];
				while(p1!=NULL)
				{
					p2 = p1->sibling;
					free(p1);
					p1 = p2;
				}
				break;
			case ProcDecK:
				/*p1指向函數聲明節點的第一個兒子節點--形參節點*/
				p1 = p->child[0];
				while(p1!=NULL)
				{
					p2 = p1->sibling;
					free(p1);
					p1 = p2;
				}
				/*p1指向函數聲明節點的第二個兒子結點--聲明節點*/
				p1 = p->child[1];
				freeDec(p1);
				/*p1指向函數聲明節點的三個兒子節點--函數體節點*/
				p1 = p->child[2];
				freeStm(p1);
				break;
		}
		p1 = p->sibling;
		free(p);
		p = p1;
	}
}

/***********************************************************/
/* 函數名  freeStm                                         */
/* 功  能  通過遞歸調用釋放語句類型指針空間                */
/* 說  明                    		    				   */
/***********************************************************/
void freeStm(TreeNode * p)
{
	TreeNode * t = p;
	TreeNode * p1 = NULL;
	TreeNode * p2 = NULL;
	while(t!=NULL)
	{
		switch(t->kind.stmt)
		{
			case IfK:
				/*刪除條件表達式節點*/
				freeExp(t->child[0]);
				/*刪除then語句序列部分*/
				freeStm(t->child[1]);
				/*刪除else語句序列部分*/
				freeStm(t->child[2]);
				break;
			case WhileK:
				/*刪除條件表達式節點*/
				freeExp(t->child[0]);
				/*刪除while語句序列部分*/
				freeStm(t->child[1]);
				break;
			case AssignK:
				/*刪除賦值號左側*/
				p1 = t->child[0];
				freeExp(p1);
				/*刪除賦值號右側*/
				p1 = t->child[1];
				freeExp(p1);
				break;
			case ReadK:
				break;
			case WriteK:
				/*刪除兒子節點*/
				freeExp(t->child[0]);
				break;
			case CallK:
				/*刪除左兒子(調用函數名)*/
				freeExp(t->child[0]);
				/*刪除右兒子節點(實參鏈)*/
				p1 = t->child[1];
				while(p1 !=NULL)
				{
					p2 = p1->sibling;
					freeExp(p1);
					p1 = p2;
				}
				break;

			case ReturnK:
				break;
		}
		p1 = t->sibling;
		free(t);
		t = p1;
	}
}

/***********************************************************/
/* 函數名  freeExp                                         */
/* 功  能  通過遞歸調用釋放表達式類型指針空間              */
/* 說  明                    		    				   */
/***********************************************************/
void freeExp(TreeNode * t)
{
	TreeNode * p1 = NULL;
	TreeNode * p2 = NULL;

	switch(t->kind.exp)
	{
	case OpK:
		/*刪除左操作數*/
		freeExp(t->child[0]);
		/*刪除右操作數*/
		freeExp(t->child[1]);
		break;
	case ConstK:
		/*直接刪除該節點*/
		free(t);
		break;
	case VariK:
		p1 = t;
		while (p1!=NULL)
		{
			p2 = p1->child[0];
			free(p1);
			p1 = p2;
		}
		break;
	}
}

/***********************************************************/
/* 函數名  freeTable                                       */
/* 功  能  通過遞歸調用釋放符號表空間                      */
/* 說  明                    		    				   */
/***********************************************************/
void freeTable(void)
{
	 SymbTable * p1=NULL;
	 SymbTable * p2=NULL;
	 int i = 0;

	 while(scope[i]!=NULL)
	 {
		 p1 = scope[i];
		 while(p1!=NULL)
		 {
			 p2 = p1->next;
			 free(p1);
			 p1 = p2;
		 }
		 i++;
	 }
}


/***********************************************************/
/* 函數名  freeMidCode                                     */
/* 功  能  釋放中間代碼空間			                       */
/* 說  明                    		    				   */
/***********************************************************/
void freeMidCode(void)
{
	 CodeFile  *code = firstCode;
     CodeFile  *code1 = NULL;
	 while(code!=NULL)
	 {
        code1 = code;
		code = code->next;
		free(code1);
	 }		 
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
在线影视一区二区三区| 欧美日韩一二三区| 色哟哟国产精品免费观看| 欧美一区二视频| 日韩毛片精品高清免费| 国产一区欧美二区| 91精品婷婷国产综合久久竹菊| 欧美国产激情一区二区三区蜜月| 日韩av网站在线观看| 在线日韩av片| 一区二区在线免费观看| 粉嫩av一区二区三区| 日韩欧美国产一区二区在线播放 | 日韩精品自拍偷拍| 尤物视频一区二区| 99国内精品久久| 久久久美女毛片| 开心九九激情九九欧美日韩精美视频电影| 色综合视频一区二区三区高清| 国产欧美中文在线| 国产a精品视频| 国产无人区一区二区三区| 国产一区不卡在线| 久久久久亚洲蜜桃| 理论片日本一区| 日韩一区二区三区免费看| 日韩精品视频网站| 91麻豆精品国产自产在线| 亚洲国产人成综合网站| 在线观看免费亚洲| 亚洲va中文字幕| 91精品欧美福利在线观看| 日本欧美肥老太交大片| 3751色影院一区二区三区| 丝袜美腿亚洲色图| 日韩久久久精品| 国模套图日韩精品一区二区| 久久久国际精品| 国产综合久久久久影院| 精品国产成人在线影院| 加勒比av一区二区| 久久九九久精品国产免费直播| 国产成人丝袜美腿| 中文字幕在线观看一区二区| 色88888久久久久久影院野外| 亚洲另类在线视频| 91麻豆精品国产91久久久使用方法 | 91精品国产综合久久香蕉麻豆| 亚洲电影一级黄| 欧美一区二区日韩| 国产精品911| 亚洲精品免费一二三区| 欧美美女喷水视频| 国产综合久久久久久久久久久久| 国产欧美日本一区二区三区| 色哟哟精品一区| 久久国产精品免费| 中文字幕一区二区三区av| 欧美色成人综合| 国产一区二区在线影院| 亚洲天堂久久久久久久| 56国语精品自产拍在线观看| 国产毛片一区二区| 一区二区在线观看视频在线观看| 欧美一区二区免费视频| 国产·精品毛片| 亚洲午夜在线电影| 久久久精品国产免费观看同学| 色婷婷精品大在线视频| 久久99精品一区二区三区| 国产精品乱码一区二三区小蝌蚪| 欧美私模裸体表演在线观看| 国产一区二区三区| 亚洲综合丁香婷婷六月香| 26uuu国产在线精品一区二区| 91蝌蚪porny九色| 国产99精品在线观看| 亚洲一级在线观看| 国产亚洲婷婷免费| 日韩一区二区电影网| 91在线看国产| 国产麻豆成人精品| 日韩国产精品久久久| 亚洲乱码国产乱码精品精98午夜 | 美日韩一区二区| 1000精品久久久久久久久| 91精品国产美女浴室洗澡无遮挡| 成人丝袜视频网| 精品中文字幕一区二区| 亚洲成年人网站在线观看| 中文av字幕一区| 精品1区2区在线观看| 欧美日韩成人一区二区| 色诱视频网站一区| 成人免费视频一区| 懂色av中文一区二区三区| 日产国产欧美视频一区精品| 亚洲国产美女搞黄色| 亚洲欧美成人一区二区三区| 亚洲国产精品二十页| 久久久精品日韩欧美| 久久综合久久综合久久| 精品国精品国产尤物美女| 欧美挠脚心视频网站| 欧美在线综合视频| 在线精品视频一区二区| 一本色道久久综合亚洲91| 一本久久精品一区二区| 一本大道久久a久久综合| 99re6这里只有精品视频在线观看| 国产剧情一区在线| 高清不卡在线观看| 成人视屏免费看| 99久久精品国产一区二区三区| 懂色av一区二区夜夜嗨| 成人av电影在线播放| 北条麻妃一区二区三区| 91丨九色丨尤物| 在线视频欧美区| 7777精品伊人久久久大香线蕉经典版下载 | 亚洲高清久久久| 亚洲一区自拍偷拍| 日韩精品一二三区| 蜜芽一区二区三区| 久久国产精品无码网站| 国产馆精品极品| 94-欧美-setu| 欧美日韩免费视频| 欧美xxx久久| 亚洲国产精品二十页| 亚洲天堂久久久久久久| 午夜精品久久久久久久99樱桃| 日韩和欧美的一区| 国产精品自拍av| 色婷婷av一区二区三区软件 | 久久久久久久综合狠狠综合| 中文字幕欧美三区| 亚洲人成影院在线观看| 日韩精品欧美精品| 国产麻豆成人传媒免费观看| www.视频一区| 欧美高清性hdvideosex| 久久久精品国产免费观看同学| 亚洲色图在线看| 免费在线成人网| 99久久精品国产导航| 欧美日韩国产一级| 久久综合久久综合久久| 一二三区精品福利视频| 国产精品一线二线三线精华| 在线看不卡av| 久久精品亚洲麻豆av一区二区| 亚洲男女一区二区三区| 另类中文字幕网| 色婷婷综合久久久久中文一区二区| 欧美一区二区免费视频| 亚洲日本在线看| 国产在线乱码一区二区三区| 在线亚洲精品福利网址导航| 久久综合网色—综合色88| 亚洲综合图片区| 大白屁股一区二区视频| 777奇米四色成人影色区| 亚洲视频在线观看一区| 久久精品国产久精国产爱| 91免费版在线| 久久精品一区八戒影视| 图片区日韩欧美亚洲| 91欧美一区二区| 中文在线免费一区三区高中清不卡| 天堂成人免费av电影一区| 91黄色在线观看| 国产精品水嫩水嫩| 韩国三级中文字幕hd久久精品| 欧美嫩在线观看| 亚洲制服丝袜一区| 色一情一乱一乱一91av| 国产午夜精品理论片a级大结局| 青青国产91久久久久久| 欧美日韩一区二区三区视频| 日韩美女久久久| 91一区在线观看| 中文字幕日韩av资源站| 丁香桃色午夜亚洲一区二区三区| 日韩精品自拍偷拍| 免费观看91视频大全| 欧美精品色综合| 五月天激情综合网| 欧美久久高跟鞋激| 亚洲成人黄色小说| 欧美精品久久天天躁| 亚洲成精国产精品女| 欧美视频精品在线| 亚洲午夜视频在线| 欧美日韩一区在线观看| 天堂资源在线中文精品| 3atv一区二区三区| 美女免费视频一区| 欧美不卡视频一区| 国产精品99久久久久久有的能看|