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

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

?? tm.cpp

?? 學習編譯原理
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
/***** 該代碼文件所包含頭文件 *****/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
/* 宏定義常量TRUE為1 */
#ifndef TRUE
#define TRUE 1
#endif
/* 宏定義常量FALSE為0 */
#ifndef FALSE
#define FALSE 0
#endif


/***************** 常量 *******************/

/* 為大型程序擴展,指令存儲區大小,定義為1024 */
#define   IADDR_SIZE  1024 
/* 為大型程序擴展,數據存儲區大小,定義為1024 */
#define   DADDR_SIZE  1024 
/* 寄存器數量,定義為8 */
#define   NO_REGS 8
/* PC寄存器,定義為7 */
#define   PC_REG  7
/* 目標代碼行大小,定義為121 */
#define   LINESIZE  121
/* 字大小,定義為20 */
#define   WORDSIZE  20


/**************** 類型 *******************/

/* 指令尋址模式類型 */
typedef enum 
{
   opclRR,		/* 寄存器尋址模式類型,操作數使用寄存器r,s,t */
   opclRM,		/* 寄存器-內存尋址模式類型,操作數使用寄存器r,內存地址d+s */
   opclRA		/* 寄存器-立即數尋址模式類型,操作數使用寄存器r,立即數值d+s */
} OPCLASS;

/* 操作指令標識碼類型 */
typedef enum opcode{

   /************* 寄存器尋址模式指令標識碼 ***************/

   opHALT,	/* 停止指令:結束程序執行,忽略操作數 */
   
   opIN,	/* 輸入指令:將外部變量讀入寄存器,使用第r個寄存器,忽略s,t參數 */

   opOUT,	/* 輸出指令:將寄存器的值輸出,使用第r個寄存器,忽略s,t參數 */

   opADD,   /* 加法指令:寄存器r的值賦為寄存器s的值與寄存器t的值的和 */

   opSUB,   /* 減法指令:寄存器r的值賦為寄存器s的值與寄存器t的值的差 */

   opMUL,   /* 乘法指令:寄存器r的值賦為寄存器s的值與寄存器t的值的積 */

   opDIV,   /* 除法指令:寄存器r的值賦為寄存器s的值與寄存器t的值的商 */

   /* 寄存器尋址模式指令限制標志,							*
    * 操作標識碼枚舉值小于opRRLim的指令均為寄存器尋址模式指令	*/
   opRRLim,  

   /************** 寄存器-內存尋址模式指令標識碼 ****************/

   opLD,	/* 載入指令:寄存器r的值賦為地址為d+reg(s)的內存單元的值 */

   opST,    /* 設置指令:將地址為d+reg(s)的內存單元值賦為寄存器r的值 */

   /* 寄存器-內存尋址模式指令限制標志										*
    * 操作標識碼枚舉值小于opRMLim且大于opRRLim的均為寄存器-內存尋址模式指令 */
   opRMLim, 

  
   /************* 寄存器-立即數尋址模式指令標識碼 ****************/

   opLDA,	/* 載入指令:將寄存器r的值賦為立即數d與寄存器s的值的和 */

   opLDC,   /* 載入指令:將寄存器r的值賦為立即數d,參數s被忽略 */

   opJLT,   /* 如果寄存器r的值小于0,將第7個寄存器的值賦為d+reg(s)	*
			 * 第7個寄存器為pc程序計數寄存器						*/

   opJLE,   /* 如果寄存器r的值小于等于0,將pc寄存器的值賦為d+reg(s) */

   opJGT,   /* 如果寄存器r的值大于0,將pc寄存器的值賦為d+reg(s) */

   opJGE,   /* 如果寄存器r的值大于等于0,將pc寄存器的值賦為d+reg(s) */

   opJEQ,   /* 如果寄存器r的值等于0,將pc寄存器的值賦為d+reg(s) */

   opJNE,   /* 如果寄存器r的值不等于0,將pc寄存器的值賦為d+reg(s) */

   /* 寄存器-立即數尋址模式指令限制標志
    * 操作標識碼枚舉值小于opRALim且大于opRMLim的均為寄存器-立即數尋址模式指令 */
   opRALim    

   } OPCODE;						

/************ 指令單步執行結果類型 ************/
typedef enum {
   srOKAY,			/* 正常 */

   srHALT,			/* 停止 */

   srIMEM_ERR,		/* 指令存儲錯 */

   srDMEM_ERR,		/* 數據存儲錯 */

   srZERODIVIDE		/* 除數為零錯 */

   } STEPRESULT;

/* 指令結構類型:操作碼,操作數1,操作數2,操作數3 */
typedef struct {
      int iop  ;
      int iarg1  ;
      int iarg2  ;
      int iarg3  ;
   } INSTRUCTION;


/******** 變量 ********/

int iloc = 0 ;			/* 指令存儲計數指針,初始為0 */

int dloc = 0 ;			/* 數據存儲計數指針,初始為0 */

int traceflag = FALSE;	/* 指令執行追蹤標志,初始為FALSE */

int icountflag = FALSE;	/* 指令執行計數標志,初始為FALSE */

/* iMem用于指令存儲,為1024長的指令結構數組 */
INSTRUCTION iMem [IADDR_SIZE];				

/* dMem用于數據存儲,為1024長的整數類型數組 */
int dMem [DADDR_SIZE];						

/* reg用于寄存器存儲,為8長的整數類型數組 */
int reg [NO_REGS];							


/* 指令操作碼表,對應尋址模式分為三類 */
char * opCodeTab[]

        = {"HALT","IN","OUT","ADD","SUB","MUL","DIV","????",
          /* 寄存器尋址模式指令類型 */

           "LD","ST","????", 
		  /* 寄存器-內存尋址模式指令類型 */

           "LDA","LDC","JLT","JLE","JGT","JGE","JEQ","JNE","????"
          /* 寄存器-立即數尋址模式指令類型 */
          };

/** 單步執行結果狀態表 **/
char * stepResultTab[]

        = {"OK","Halted","Instruction Memory Fault",
           "Data Memory Fault","Division by 0"
          };

char pgmName[20];			/* 用于存儲程序文件名 */

FILE *pgm  ;				/* 程序文件指針 */

char in_Line[LINESIZE] ;	/* 用于存儲一行代碼,為121長的字符數組 */

int lineLen ;				/* in_Line中行結尾字符位置 */

int inCol  ;				/* 用于指出在in_Line中的當前字符位置 */

int num  ;					/* 用于存儲當前所得數值 */

char word[WORDSIZE] ;		/* 用于存儲當前的字,為20長的字符數組 */

char ch  ;					/* 當前代碼行中當前位置上的字符 */

int done  ;



/****************************************************/
/* 函數名 opClass									*/
/* 功  能 指令尋址模式分類函數						*/
/* 說  明 該函數對給定的指令操作碼枚舉值c進行分類	*/
/*        返回指令所屬尋址模式						*/
/****************************************************/
int opClass( int c )

{ 
  /* 如果枚舉值c小于opRRLim,則指令為寄存器尋址模式指令類型 */
  if      ( c <= opRRLim) return ( opclRR );

  /* 如果枚舉值c小于opRMLim,則指令為寄存器-內存尋址模式指令類型 */
  else if ( c <= opRMLim) return ( opclRM );

  /* 為寄存器-立即數尋址模式指令類型 */
  else                    return ( opclRA );

} 

/********************************************************/
/* 函數名 writeInstruction								*/
/* 功  能 指令輸出函數									*/
/* 說  明 該函數將指令存儲區中指令以指定格式輸出到屏幕	*/
/********************************************************/
void writeInstruction ( int loc )

{  
  /* loc為所要輸出的指令在指令存儲區中地址,輸出到屏幕 */
  printf( "%5d: ", loc) ;

  /* 輸出指令地址loc在0-1023有效的指令存儲區地址范圍之內 */
  if ( (loc >= 0) && (loc < IADDR_SIZE) )

  { 
    /* 輸出地址為loc上的指令操作碼值iMem[loc].iop和第一操作數iMem[loc].iarg1 */
	printf("%6s%3d,", opCodeTab[iMem[loc].iop], iMem[loc].iarg1);

	/* 根據指令的尋址模式分類處理 */
    switch ( opClass(iMem[loc].iop) )

    { 
      /* 輸出指令為寄存器尋址模式指令,以給定形式輸出操作數2,操作數3 */
	  case opclRR: printf("%1d,%1d", iMem[loc].iarg2, iMem[loc].iarg3);
                   break;		

      /* 輸出指令為寄存器-立即數尋址模式指令,和寄存器-內存尋址模式指令	*
	   * 以給定形式輸出操作數2,操作數3									*/
      case opclRM: 
      case opclRA: printf("%3d(%1d)", iMem[loc].iarg2, iMem[loc].iarg3);
                   break;	
    }
   	/* 向屏幕輸出換行符 */
	printf ("\n") ;
  }
} /* writeInstruction */

/****************************************************/
/* 函數名 getCh										*/
/* 功  能 字符獲取函數								*/
/* 說  明 如果當前行中字符未讀完,則函數返回當前字符	*/
/*		  否則,函數返回空格字符						*/
/****************************************************/
void getCh (void)

{ 
  /* 在當前代碼行in_Line中,當前字符列數inCol未超過代碼行實際長度lineLen *
   * 取得當前行中當前位置的字符,送入ch									*/
  if (++inCol < lineLen)
  ch = in_Line[inCol] ;

  /* 如果inCol超出當前代碼行長度范圍,則ch賦為空格 */
  else ch = ' ' ;

} /* getCh */



/********************************************************/
/* 函數名 nonBlank										*/
/* 功  能 非空字符獲取函數								*/
/* 說  明 如果成功從當前行中取得非空字符,函數返回TRUE	*/
/*		  否則,函數返回FALSE							*/
/********************************************************/
int nonBlank (void)

{ 
  /* 在當前代碼行in_Line中,當前字符位置inCol中為空格字符	*  
   * 在當前代碼行in_Line中,當前字符位置inCol下移,略過空格	*/
  while ((inCol < lineLen)
         && (in_Line[inCol] == ' ') )
		 inCol++ ;

  /* 在當前代碼行in_Line中,遇到非空字符 */
  if (inCol < lineLen)

  { 
    /* 取當前字符位置inCol中的字符送入ch,		*
	 * 函數返回TRUE(已定義為1),ch中得到非空字符	*/
	ch = in_Line[inCol] ;
    return TRUE ; }

  /* 當前代碼行已經讀完,將當前字符ch 賦為空格,	*
   * 函數返回FALSE(已定義為0),ch中為空格字符	*/
  else
  { ch = ' ' ;
    return FALSE ; }
} /* nonBlank */


/****************************************************************/
/* 函數名 getNum												*/
/* 功  能 數值獲取函數											*/
/* 說  明 將代碼行中連續出現的有加減運算的數term合并計數,		*/
/*        所的數值送入為num.如果成功得到數值,則函數返回TRUE;	*/
/*        否則,函數返回FALSE									*/
/****************************************************************/
int getNum (void)

{ int sign;				/* 符號因子 */

  int term;				/* 用于記錄當前錄入的局部數值 */

  int temp = FALSE;		/* 記錄函數返回值,初始為假 */

  num = 0 ;				/* 用于記錄所有加減運算后的最終數值結果 */

  do
  { sign = 1;			/* 符號因子初始為1 */

    /* 調用函數nonBlank()略過當前位置的空格后,			*
     * 所得到的當前非空字符ch為+或-.(+/-的連續出現處理)	*/
    while ( nonBlank() && ((ch == '+') || (ch == '-')) )

    { temp = FALSE ;

	  /* 當前字符ch為"-"時,符號因子sign設為-1 */
	  if (ch == '-')  sign = - sign ;

	  /* 取當前代碼行中下一字符到當前字符ch中 */
      getCh();
    }

    term = 0 ;		/* 當前錄入的局部數值初始為0 */

    nonBlank();		/* 略過當前位置上的空格 */

	/* 當前字符ch為數字,局部數值的循環處理 */
    while (isdigit(ch))				

    { temp = TRUE ;		/* 函數返回值設為TRUE,成功得到數字 */

	  /* 將字符序列轉化為數值形式,進行進位累加 */
      term = term * 10 + ( ch - '0' ) ;

      getCh();			/* 取當前代碼行中下一字符到當前字符ch中 */

    }
	/* 將局部數值帶符號累加,得到最終數值num */
    num = num + (term * sign) ;

  } while ( (nonBlank()) && ((ch == '+') || (ch == '-')) ) ;
  return temp;
} /* getNum */


/****************************************************/
/* 函數名 getWord									*/
/* 功  能 單詞獲取函數								*/
/* 說  明 函數從當前代碼行中獲取單詞.如果得到字符,	*/
/*		  則函數返回TRUE;否則,函數返回FALSE			*/
/****************************************************/
int getWord (void)

{ 
	
  int temp = FALSE;			/* 函數返回值初始為FALSE */

  int length = 0;			/* 單詞長度初始為0 */

  /* 在當前代碼行中成功獲取非空字符ch */
  if (nonBlank ())

  {
    /* 當前非空字符ch為字母或數字 */
	while (isalnum(ch))

    {
      /* 當前單詞word未超過規定字長WORDSIZE-1(為單詞結束字符留一空位)	*
	   * 將當前字符ch讀入到單詞末尾										*/
	  if (length < WORDSIZE-1) word [length++] =  ch ;

      getCh() ;			/* 取當前代碼行中下一字符 */
    }

	/* 給當前單詞word加入結束字符 */
    word[length] = '\0';

	/* 設置函數返回值,當讀入字word非空的時候為TRUE */
    temp = (length != 0);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日产国产欧美视频一区精品| 亚洲电影激情视频网站| 欧美日韩国产精选| 欧美性大战久久久| 欧美三级资源在线| 欧美久久久久久蜜桃| 67194成人在线观看| 51午夜精品国产| 欧美一区二区三区免费| 欧美一级精品大片| 欧美va在线播放| 久久影院午夜论| 国产精品久久二区二区| 国产精品卡一卡二卡三| 中文字幕欧美一区| 亚洲福利电影网| 久久电影网站中文字幕| 国产传媒欧美日韩成人| 99精品视频在线观看| 日本高清不卡在线观看| 在线观看91av| 久久精品欧美日韩精品| 国产精品久久久久一区二区三区| 一色桃子久久精品亚洲| 夜夜爽夜夜爽精品视频| 蜜桃一区二区三区在线观看| 国产一区二区福利| 91免费看片在线观看| 欧美日韩成人综合在线一区二区| 精品国产一二三| 亚洲色图丝袜美腿| 免费观看30秒视频久久| 国产成人精品网址| 欧美色网站导航| 国产视频亚洲色图| 亚洲一级二级三级| 国产美女视频一区| 欧美剧在线免费观看网站| 久久免费午夜影院| 日韩福利电影在线| 91麻豆免费看| 国产夜色精品一区二区av| 亚洲综合色区另类av| 韩国成人在线视频| 欧美日韩成人综合在线一区二区| 国产网站一区二区三区| 视频在线观看91| 91免费视频网| 国产精品三级av在线播放| 日韩av一区二| 欧美亚洲综合网| 亚洲精品精品亚洲| 国产成人在线视频免费播放| 6080亚洲精品一区二区| 亚洲激情图片qvod| 色综合网色综合| 国产精品色在线观看| 国内成+人亚洲+欧美+综合在线| 91精品福利视频| 国产精品国产三级国产aⅴ入口| 麻豆精品一区二区| 91精品国产综合久久小美女| 亚洲制服丝袜一区| 在线视频观看一区| 亚洲欧美日韩国产综合| 成人美女在线视频| 国产精品久久久久aaaa樱花| 国产一区在线观看麻豆| 日韩精品一区二区在线| 亚洲电影视频在线| 欧美视频精品在线| 亚洲午夜日本在线观看| 色综合天天综合色综合av| 中文字幕的久久| 成人97人人超碰人人99| 国产精品理论在线观看| 99精品欧美一区二区蜜桃免费| 久久精品网站免费观看| 成人永久aaa| 亚洲欧美日韩国产综合在线| 91色porny| 午夜精品久久久| 欧美精品丝袜久久久中文字幕| 亚洲成人动漫av| 精品国产乱码久久| 成人丝袜高跟foot| 亚洲免费在线电影| 欧美喷潮久久久xxxxx| 男女性色大片免费观看一区二区| 欧美老年两性高潮| 国产一区二区三区香蕉 | 亚洲免费在线电影| 在线观看国产精品网站| 亚洲国产成人av好男人在线观看| 欧美日韩一区二区三区四区| 日韩av一区二区三区四区| 欧美精品一区二区三区在线播放| 国产精品中文字幕日韩精品| 久久人人爽人人爽| 91福利国产精品| 蜜桃传媒麻豆第一区在线观看| 久久婷婷色综合| 91麻豆免费看片| 美女视频黄免费的久久 | 亚洲图片欧美综合| 精品免费一区二区三区| 成人sese在线| 人人精品人人爱| 亚洲欧美中日韩| 日韩一二三区视频| 成人ar影院免费观看视频| 日韩在线观看一区二区| 国产日韩欧美制服另类| 欧美日韩亚洲另类| 国产99久久精品| 亚洲成av人片观看| 国产精品日韩成人| 精品国产亚洲在线| 欧美日韩成人一区二区| 99精品热视频| 国产精品性做久久久久久| 亚洲主播在线观看| 日韩一区欧美一区| 久久久精品影视| 日韩区在线观看| 欧洲另类一二三四区| 成人免费毛片嘿嘿连载视频| 日韩专区在线视频| 一区二区三区国产| 亚洲图片另类小说| 国产日韩欧美综合一区| 欧美大片免费久久精品三p | 欧美日韩精品欧美日韩精品一综合| 国产精品1024| 久久99在线观看| 日本午夜精品视频在线观看 | 亚洲小说欧美激情另类| 国产精品久久久久7777按摩| 欧美videossexotv100| 777午夜精品视频在线播放| 欧美午夜理伦三级在线观看| 成人a区在线观看| 国产电影精品久久禁18| 国产一级精品在线| 国产一二三精品| 国产中文字幕精品| 国内久久精品视频| 国产一本一道久久香蕉| 国产制服丝袜一区| 精品一区二区精品| 精品无人码麻豆乱码1区2区 | 欧美激情综合五月色丁香小说| 日韩精品在线一区二区| 日韩欧美aaaaaa| wwwwww.欧美系列| 国产午夜亚洲精品不卡| 久久久99精品免费观看不卡| 久久亚洲综合av| 中文字幕欧美国产| 国产精品乱码人人做人人爱| 中文一区二区在线观看| 中文字幕一区在线| 伊人一区二区三区| 午夜视频久久久久久| 日本不卡123| 国产精品综合网| 色综合久久中文字幕综合网| 91丨porny丨在线| 在线91免费看| 国产日韩欧美高清在线| 亚洲免费观看视频| 青椒成人免费视频| 国产成人精品影院| 91久久一区二区| 制服丝袜激情欧洲亚洲| 久久精品视频免费| 亚洲影院在线观看| 久久精品免费看| 91在线国产观看| 日韩一区二区三区三四区视频在线观看| 日韩欧美不卡在线观看视频| 久久久久久久久久久黄色| 亚洲欧美一区二区三区孕妇| 日韩高清一区二区| 99国产一区二区三精品乱码| 欧美日本视频在线| 国产精品水嫩水嫩| 五月天激情小说综合| 国产美女久久久久| 69堂国产成人免费视频| 国产精品国产自产拍在线| 午夜激情久久久| 成人动漫av在线| 日韩免费电影网站| 亚洲免费看黄网站| 国产成人亚洲综合a∨婷婷图片| 欧美在线一二三| 国产精品少妇自拍| 麻豆传媒一区二区三区| 欧美丝袜丝nylons|