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

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

?? fc-interpret.cpp

?? 編譯原理的一個課程設計
?? CPP
?? 第 1 頁 / 共 2 頁
字號:
#include "stdafx.h"
#include "FC.h"
#include "FCDlg.h"
#include "FCInputDlg.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

BOOL CFCDlg::TestAddress(int iAddress)
{
	if(iAddress>=nMEMORY)
	{
		Output("\r\n地址溢出,程序停止執行!\r\n");
		MessageBeep(0);
		return FALSE;
	}
	return TRUE;
}

BOOL CFCDlg::ZeroSlashMod(int i)
{
	if(i==0)
	{
		Output("\r\n“/”或“%”的右操作數為0,程序停止執行!\r\n");
		MessageBeep(0);
		return FALSE;
	}
	return TRUE;
}

BOOL CFCDlg::ZeroSlashMod(double d)
{
	if(d==0.0)
	{
		Output("\r\n“/”或“%”的右操作數為0,程序停止執行!\r\n");
		MessageBeep(0);
		return FALSE;
	}
	return TRUE;
}

BOOL CFCDlg::ArraySubscript(int index,int length)
{
	if(index<0 || (length>=0 && index>=length))
	{
		Output("\r\n數組下標溢出,程序停止執行!\r\n");
		MessageBeep(0);
		return FALSE;
	}
	return TRUE;
}

BOOL CFCDlg::ValideArray(void *pArray)
{
	if(pArray==NULL)
	{
		Output("\r\n無法分配數組空間,程序停止執行!\r\n");
		MessageBeep(0);
		return FALSE;
	}
	return TRUE;
}

// CFCDlg 運行函數
BOOL CFCDlg::Interpret(void)
{
	const double m_iCode=0;//定義此變量只是為了屏蔽外部成員變量

	int i,n,iTemp;
	double dTemp;

	register int iBase=0;		//函數基地址
	register int iCode=0;		//代碼指針
	register int iAddress=0;	//地址指針
	ZMemory memory[nMEMORY];	//虛內存

	register int iOp;			//指令條數計數
	BOOL bWarning=TRUE;			//是否對可能的死循環進行警告

	clock_t tStart,tElapse=0;
	tStart=clock();

	for(iOp=0;;iOp++)
	{
		if(iOp==17333 && bWarning)//17333只是表示173班33號,無其他意義
		{
			tElapse+=clock()-tStart;
			switch(MessageBox("\
程序可能進入死循環,要中止解釋執行嗎?\n\
按“是”中止解釋執行,按“否”繼續解釋執行\n\
按“取消”繼續解釋執行并不再顯示此消息框",
				"FC 2.2",MB_YESNOCANCEL|MB_ICONQUESTION))
			{
			case IDYES:
				tStart=clock();
				goto EndInterpret;
				//此處無需break語句
			case IDCANCEL:
				bWarning=FALSE;
				//此處不填入break語句
			case IDNO:
				tStart=clock();
				iOp=0;
				break;
			}
		}
		switch(m_code[iCode].op)
		{
		case OP_AND:				//邏輯與
			if(memory[iAddress-1].iNumber!=0 && memory[iAddress].iNumber!=0)
				memory[iAddress-1].iNumber=1;
			else memory[iAddress-1].iNumber=0;
			iAddress--;
			iCode++;
			break;
		case OP_CALL:				//調用函數
			if(!TestAddress(iAddress+3))// +3 是因為下邊需要3單元虛內存
				return FALSE;
			memory[iAddress+1].iNumber=iBase;	//保留原基地址
			memory[iAddress+2].iNumber=iAddress;//保留原棧頂指針
			memory[iAddress+3].iNumber=iCode;	//保留原中間代碼指針
			iBase=iAddress+1;
			iCode=m_code[iCode].sd.iNumber;
			iAddress+=m_code[iCode].sd.iNumber+3;
			iCode++;
			break;
		case OP_CHANGESIGNALD:		//實數變號
			memory[iAddress].dNumber= -memory[iAddress].dNumber;
			iCode++;
			break;
		case OP_CHANGESIGNALI:		//整數變號
			memory[iAddress].iNumber= -memory[iAddress].iNumber;
			iCode++;
			break;
		case OP_COPYD:				//復制棧頂實數
			iAddress++;
			if(!TestAddress(iAddress))
				return FALSE;
			memory[iAddress].dNumber=memory[iAddress-1].dNumber;
			iCode++;
			break;
		case OP_COPYI:				//復制棧頂整數
			iAddress++;
			if(!TestAddress(iAddress))
				return FALSE;
			memory[iAddress].iNumber=memory[iAddress-1].iNumber;
			iCode++;
			break;
		case OP_D2I:				//實數變整數
			memory[iAddress+m_code[iCode].sd.iNumber].iNumber=
				(int)memory[iAddress+m_code[iCode].sd.iNumber].dNumber;
			iCode++;
			break;
		case OP_DELARRAYD:			//刪除實數數組
			delete memory[iBase+3+m_code[iCode].sd.iNumber].dArray;
			iCode++;
			break;
		case OP_DELARRAYI:			//刪除整型數組
			delete memory[iBase+3+m_code[iCode].sd.iNumber].iArray;
			iCode++;
			break;
		case OP_DELETE:				//刪除棧頂數
			iAddress--;
			iCode++;
			break;
		case OP_EQUALD:				//實數相等
			if(memory[iAddress-1].dNumber == memory[iAddress].dNumber)
				memory[iAddress-1].iNumber=1;
			else memory[iAddress-1].iNumber=0;
			iAddress--;
			iCode++;
			break;
		case OP_EQUALI:				//整數相等
			if(memory[iAddress-1].iNumber == memory[iAddress].iNumber)
				memory[iAddress-1].iNumber=1;
			else memory[iAddress-1].iNumber=0;
			iAddress--;
			iCode++;
			break;
		case OP_EXIT:				//程序結束標志
			goto EndInterpret;
		case OP_GREATD:				//實數大于
			if(memory[iAddress-1].dNumber > memory[iAddress].dNumber)
				memory[iAddress-1].iNumber=1;
			else memory[iAddress-1].iNumber=0;
			iAddress--;
			iCode++;
			break;
		case OP_GREATEQUALD:		//實數大于等于
			if(memory[iAddress-1].dNumber >= memory[iAddress].dNumber)
				memory[iAddress-1].iNumber=1;
			else memory[iAddress-1].iNumber=0;
			iAddress--;
			iCode++;
			break;
		case OP_GREATEQUALI:		//整數大于等于
			if(memory[iAddress-1].iNumber >= memory[iAddress].iNumber)
				memory[iAddress-1].iNumber=1;
			else memory[iAddress-1].iNumber=0;
			iAddress--;
			iCode++;
			break;
		case OP_GREATI:				//整數大于
			if(memory[iAddress-1].iNumber > memory[iAddress].iNumber)
				memory[iAddress-1].iNumber=1;
			else memory[iAddress-1].iNumber=0;
			iAddress--;
			iCode++;
			break;
		case OP_I2D:				//整數變實數
			memory[iAddress+m_code[iCode].sd.iNumber].dNumber=
				(double)memory[iAddress+m_code[iCode].sd.iNumber].iNumber;
			iCode++;
			break;
		case OP_INPUTARRAYD:		//輸入實數數組
			iTemp=iBase+3+m_code[iCode].sd.iNumber;//數組頭位置
			i=memory[iAddress].iNumber;//數組下標
			if(!ArraySubscript(i,memory[iTemp].length))//下標檢查
				return FALSE;
			tElapse+=clock()-tStart;
			memory[iTemp].dArray[i]=InputDouble();
			tStart=clock();
			iAddress--;
			iCode++;
			break;
		case OP_INPUTARRAYI:		//輸入整數數組
			iTemp=iBase+3+m_code[iCode].sd.iNumber;//數組頭位置
			i=memory[iAddress].iNumber;//數組下標
			if(!ArraySubscript(i,memory[iTemp].length))//下標檢查
				return FALSE;
			tElapse+=clock()-tStart;
			memory[iTemp].iArray[i]=InputInt();
			tStart=clock();
			iAddress--;
			iCode++;
			break;
		case OP_INPUTD:				//輸入實型值
			tElapse+=clock()-tStart;
			memory[iBase+3+m_code[iCode].sd.iNumber].dNumber=InputDouble();
			tStart=clock();
			iCode++;
			break;
		case OP_INPUTI:				//輸入整型值
			tElapse+=clock()-tStart;
			memory[iBase+3+m_code[iCode].sd.iNumber].iNumber=InputInt();
			tStart=clock();
			iCode++;
			break;
		case OP_JUMP:				//無條件跳轉
			iCode=m_code[iCode].sd.iNumber;
			break;
		case OP_JUMPC:				//條件跳轉
			if(memory[iAddress].iNumber!=0)
				iCode=m_code[iCode].sd.iNumber;
			else iCode++;
			iAddress--;
			break;
		case OP_LESSD:				//實數小于
			if(memory[iAddress-1].dNumber < memory[iAddress].dNumber)
				memory[iAddress-1].iNumber=1;
			else memory[iAddress-1].iNumber=0;
			iAddress--;
			iCode++;
			break;
		case OP_LESSEQUALD:			//實數小于等于
			if(memory[iAddress-1].dNumber <= memory[iAddress].dNumber)
				memory[iAddress-1].iNumber=1;
			else memory[iAddress-1].iNumber=0;
			iAddress--;
			iCode++;
			break;
		case OP_LESSEQUALI:			//整數小于等于
			if(memory[iAddress-1].iNumber <= memory[iAddress].iNumber)
				memory[iAddress-1].iNumber=1;
			else memory[iAddress-1].iNumber=0;
			iAddress--;
			iCode++;
			break;
		case OP_LESSI:				//整數小于
			if(memory[iAddress-1].iNumber < memory[iAddress].iNumber)
				memory[iAddress-1].iNumber=1;
			else memory[iAddress-1].iNumber=0;
			iAddress--;
			iCode++;
			break;
		case OP_LOADARRAYD:			//導入實數數組
			iTemp=iBase+3+m_code[iCode].sd.iNumber;//數組頭位置

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人一区二区在线观看| 欧美一级国产精品| 国产乱码字幕精品高清av| 秋霞电影一区二区| 亚洲国产你懂的| 亚洲国产日韩在线一区模特 | 蜜臀av一区二区在线免费观看 | 成人黄色777网| 国产成都精品91一区二区三| 国产传媒久久文化传媒| 国产精品一区一区| 99在线精品免费| 欧美视频一区二区三区| 欧美蜜桃一区二区三区| 欧美一区二区成人| 26uuu亚洲| 久久你懂得1024| 国产女人18毛片水真多成人如厕| 国产日韩精品一区| 国产精品卡一卡二| 亚洲色大成网站www久久九九| 91色乱码一区二区三区| 国产精品性做久久久久久| 国产精品一区二区在线观看网站| 欧美色网站导航| 欧美精品第一页| 久久久久久久久久久久久夜| 亚洲欧洲精品一区二区精品久久久| 亚洲精品少妇30p| 日韩在线一区二区三区| 国产麻豆日韩欧美久久| 色8久久精品久久久久久蜜 | 亚洲自拍偷拍av| 琪琪一区二区三区| av资源网一区| 日韩精品自拍偷拍| 日韩理论在线观看| 日韩成人伦理电影在线观看| 不卡视频一二三| 777奇米四色成人影色区| 久久影音资源网| 亚洲国产精品一区二区尤物区| 久久99在线观看| 91黄色免费看| 久久免费偷拍视频| 日韩在线卡一卡二| 97精品久久久午夜一区二区三区 | 7777精品伊人久久久大香线蕉的 | 美女高潮久久久| 天堂资源在线中文精品| 成人国产精品免费网站| 日韩三级伦理片妻子的秘密按摩| 国产精品福利一区| 激情文学综合丁香| 日韩一区二区高清| 亚洲欧美色一区| 风间由美一区二区三区在线观看 | 欧美本精品男人aⅴ天堂| 一区二区三区在线看| 成人污视频在线观看| 欧美一级欧美一级在线播放| 亚洲黄网站在线观看| 成人激情文学综合网| 久久午夜羞羞影院免费观看| 日本不卡一二三| 欧美色欧美亚洲另类二区| 国产精品久久久久影视| 国产精品一二三| 久久欧美一区二区| 老司机精品视频线观看86 | 精品少妇一区二区| 日本成人在线不卡视频| 成人av在线电影| 日韩精品每日更新| 一本色道久久综合狠狠躁的推荐 | 中文字幕在线观看不卡| 国产很黄免费观看久久| 日韩电影在线观看一区| 欧美视频在线不卡| 亚洲一区二区三区国产| 欧美日精品一区视频| 亚洲一区在线观看免费 | 精品国产3级a| 精品一区二区免费| xnxx国产精品| 国产iv一区二区三区| 中文字幕在线观看一区| 色哟哟精品一区| 亚洲国产精品久久久男人的天堂| 欧美精品xxxxbbbb| 美女性感视频久久| 欧美国产一区在线| 色欲综合视频天天天| 亚洲午夜精品在线| 欧美日韩成人综合| 九九热在线视频观看这里只有精品| 2021中文字幕一区亚洲| 9久草视频在线视频精品| 成人欧美一区二区三区1314| 欧美私人免费视频| 久久成人综合网| 国产欧美日韩视频一区二区| 91蝌蚪porny| 乱中年女人伦av一区二区| 久久午夜电影网| 色丁香久综合在线久综合在线观看| 亚洲成人自拍网| 国产亚洲va综合人人澡精品| 色8久久人人97超碰香蕉987| 精品一区二区三区香蕉蜜桃| 国产精品五月天| 制服.丝袜.亚洲.另类.中文| 成人丝袜18视频在线观看| 亚洲综合色自拍一区| 精品久久国产字幕高潮| 色综合久久天天综合网| 精品写真视频在线观看| 亚洲欧美日韩国产一区二区三区| 欧美一级视频精品观看| 91蝌蚪porny| 欧美一区二区三区免费| 91丨porny丨国产| 蜜臀91精品一区二区三区| 国产精品理伦片| 精品日韩一区二区三区免费视频| 一本色道**综合亚洲精品蜜桃冫| 蜜臀av一区二区在线免费观看| 成人免费在线视频| 26uuu国产一区二区三区| 欧美色综合网站| 91影院在线免费观看| 狠狠色狠狠色综合日日91app| 亚洲h动漫在线| 亚洲欧洲中文日韩久久av乱码| 精品少妇一区二区| 欧美一区二区视频在线观看2020 | 欧美精品九九99久久| www.成人网.com| 国产酒店精品激情| 麻豆国产精品视频| 日韩精品亚洲一区| 亚洲一区二区三区四区在线观看 | aaa亚洲精品| 国产91精品一区二区麻豆网站 | av在线不卡网| 大陆成人av片| 激情成人综合网| 免费观看在线综合色| 日韩电影在线观看网站| 热久久国产精品| 麻豆精品久久精品色综合| 男男gaygay亚洲| 麻豆精品在线播放| 蜜桃av一区二区三区| 日韩av中文字幕一区二区三区| 亚洲成人一二三| 日韩精品每日更新| 免费在线看成人av| 免费久久精品视频| 国模一区二区三区白浆| 国产精品一区二区久久精品爱涩 | 在线观看免费视频综合| 99免费精品视频| 日本电影欧美片| 欧美日韩一区久久| 91精品婷婷国产综合久久竹菊| 日韩一级黄色片| 337p日本欧洲亚洲大胆精品| 国产日韩欧美一区二区三区乱码| 日本一区二区视频在线| 自拍偷拍国产精品| 亚洲午夜成aⅴ人片| 日本成人中文字幕| 国产成人在线看| 色综合久久久网| 欧美三级中文字| 精品久久久久久最新网址| 国产精品私人影院| 亚洲综合色丁香婷婷六月图片| 日韩av网站免费在线| 国产在线观看一区二区| 99精品欧美一区二区三区小说 | 亚洲影视在线播放| 麻豆国产欧美一区二区三区| 成人三级在线视频| 欧美三级乱人伦电影| 欧美不卡一区二区三区四区| 国产欧美日产一区| 亚洲综合成人在线| 精品综合久久久久久8888| www..com久久爱| 制服.丝袜.亚洲.另类.中文| 国产精品国产三级国产普通话蜜臀| 亚洲一区二区三区小说| 国产成人av一区二区三区在线观看| 色综合天天综合网国产成人综合天 | 欧美精品一区二区三区蜜桃 | 国产三级一区二区| 视频一区视频二区中文| av激情成人网|