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

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

?? tm.c

?? C語言高級編程及實例部析 by Johnzhang0921
?? C
字號:







#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>

#ifndef TRUE
#define TRUE 1
#endif
#ifndef FALSE
#define FALSE 0
#endif


#define   IADDR_SIZE  1024 
#define   DADDR_SIZE  1024 
#define   NO_REGS 8
#define   PC_REG  7

#define   LINESIZE  121
#define   WORDSIZE  20



typedef enum {
   opclRR,     
   opclRM,     
   opclRA      
   } OPCLASS;

typedef enum {
   
   opHALT,    
   opIN,      
   opOUT,     
   opADD,    
   opSUB,    
   opMUL,    
   opDIV,    reg(t) */
   opRRLim,   

   
   opLD,      
   opST,      
   opRMLim,   

   
   opLDA,     
   opLDC,     
   opJLT,     
   opJLE,     
   opJGT,     
   opJGE,     
   opJEQ,     
   opJNE,     
   opRALim    
   } OPCODE;

typedef enum {
   srOKAY,
   srHALT,
   srIMEM_ERR,
   srDMEM_ERR,
   srZERODIVIDE
   } STEPRESULT;

typedef struct {
      int iop  ;
      int iarg1  ;
      int iarg2  ;
      int iarg3  ;
   } INSTRUCTION;


int iloc = 0 ;
int dloc = 0 ;
int traceflag = FALSE;
int icountflag = FALSE;

INSTRUCTION iMem [IADDR_SIZE];
int dMem [DADDR_SIZE];
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] ;
int lineLen ;
int inCol  ;
int num  ;
char word[WORDSIZE] ;
char ch  ;
int done  ;


int opClass( int c )
{ if      ( c <= opRRLim) return ( opclRR );
  else if ( c <= opRMLim) return ( opclRM );
  else                    return ( opclRA );
} 


void writeInstruction ( int loc )
{ printf( "%5d: ", loc) ;
  if ( (loc >= 0) && (loc < IADDR_SIZE) )
  { printf("%6s%3d,", opCodeTab[iMem[loc].iop], iMem[loc].iarg1);
    switch ( opClass(iMem[loc].iop) )
    { case opclRR: printf("%1d,%1d", iMem[loc].iarg2, iMem[loc].iarg3);
                   break;
      case opclRM:
      case opclRA: printf("%3d(%1d)", iMem[loc].iarg2, iMem[loc].iarg3);
                   break;
    }
    printf ("\n") ;
  }
} 


void getCh (void)
{ if (++inCol < lineLen)
  ch = in_Line[inCol] ;
  else ch = ' ' ;
} 


int nonBlank (void)
{ while ((inCol < lineLen)
         && (in_Line[inCol] == ' ') )
    inCol++ ;
  if (inCol < lineLen)
  { ch = in_Line[inCol] ;
    return TRUE ; }
  else
  { ch = ' ' ;
    return FALSE ; }
} 


int getNum (void)
{ int sign;
  int term;
  int temp = FALSE;
  num = 0 ;
  do
  { sign = 1;
    while ( nonBlank() && ((ch == '+') || (ch == '-')) )
    { temp = FALSE ;
      if (ch == '-')  sign = - sign ;
      getCh();
    }
    term = 0 ;
    nonBlank();
    while (isdigit(ch))
    { temp = TRUE ;
      term = term * 10 + ( ch - '0' ) ;
      getCh();
    }
    num = num + (term * sign) ;
  } while ( (nonBlank()) && ((ch == '+') || (ch == '-')) ) ;
  return temp;
} 


int getWord (void)
{ int temp = FALSE;
  int length = 0;
  if (nonBlank ())
  { while (isalnum(ch))
    { if (length < WORDSIZE-1) word [length++] =  ch ;
      getCh() ;
    }
    word[length] = '\0';
    temp = (length != 0);
  }
  return temp;
} 


int skipCh ( char c  )
{ int temp = FALSE;
  if ( nonBlank() && (ch == c) )
  { getCh();
    temp = TRUE;
  }
  return temp;
} 


int atEOL(void)
{ return ( ! nonBlank ());
} 


int error( char * msg, int lineNo, int instNo)
{ printf("Line %d",lineNo);
  if (instNo >= 0) printf(" (Instruction %d)",instNo);
  printf("   %s\n",msg);
  return FALSE;
} 


int readInstructions (void)
{ OPCODE op;
  int arg1, arg2, arg3;
  int loc, regNo, lineNo;
  for (regNo = 0 ; regNo < NO_REGS ; regNo++)
      reg[regNo] = 0 ;
  dMem[0] = DADDR_SIZE - 1 ;
  for (loc = 1 ; loc < DADDR_SIZE ; loc++)
      dMem[loc] = 0 ;
  for (loc = 0 ; loc < IADDR_SIZE ; loc++)
  { iMem[loc].iop = opHALT ;
    iMem[loc].iarg1 = 0 ;
    iMem[loc].iarg2 = 0 ;
    iMem[loc].iarg3 = 0 ;
  }
  lineNo = 0 ;
  while (! feof(pgm))
  { fgets( in_Line, LINESIZE-2, pgm  ) ;
    inCol = 0 ; 
    lineNo++;
    lineLen = strlen(in_Line)-1 ;
    if (in_Line[lineLen]=='\n') in_Line[lineLen] = '\0' ;
    else in_Line[++lineLen] = '\0';
    if ( (nonBlank()) && (in_Line[inCol] != '*') )
    { if (! getNum())
        return error("Bad location", lineNo,-1);
      loc = num;
      if (loc > IADDR_SIZE)
        return error("Location too large",lineNo,loc);
      if (! skipCh(':'))
        return error("Missing colon", lineNo,loc);
      if (! getWord ())
        return error("Missing opcode", lineNo,loc);
      op = opHALT ;
      while ((op < opRALim)
             && (strncmp(opCodeTab[op], word, 4) != 0) )
          op++ ;
      if (strncmp(opCodeTab[op], word, 4) != 0)
          return error("Illegal opcode", lineNo,loc);
      switch ( opClass(op) )
      { case opclRR :
        
        if ( (! getNum ()) || (num < 0) || (num >= NO_REGS) )
            return error("Bad first register", lineNo,loc);
        arg1 = num;
        if ( ! skipCh(','))
            return error("Missing comma", lineNo, loc);
        if ( (! getNum ()) || (num < 0) || (num >= NO_REGS) )
            return error("Bad second register", lineNo, loc);
        arg2 = num;
        if ( ! skipCh(',')) 
            return error("Missing comma", lineNo,loc);
        if ( (! getNum ()) || (num < 0) || (num >= NO_REGS) )
            return error("Bad third register", lineNo,loc);
        arg3 = num;
        break;

        case opclRM :
        case opclRA :
        
        if ( (! getNum ()) || (num < 0) || (num >= NO_REGS) )
            return error("Bad first register", lineNo,loc);
        arg1 = num;
        if ( ! skipCh(','))
            return error("Missing comma", lineNo,loc);
        if (! getNum ())
            return error("Bad displacement", lineNo,loc);
        arg2 = num;
        if ( ! skipCh('(') && ! skipCh(',') )
            return error("Missing LParen", lineNo,loc);
        if ( (! getNum ()) || (num < 0) || (num >= NO_REGS))
            return error("Bad second register", lineNo,loc);
        arg3 = num;
        break;
        }
      iMem[loc].iop = op;
      iMem[loc].iarg1 = arg1;
      iMem[loc].iarg2 = arg2;
      iMem[loc].iarg3 = arg3;
    }
  }
  return TRUE;
} 



STEPRESULT stepTM (void)
{ INSTRUCTION currentinstruction  ;
  int pc  ;
  int r,s,t,m  ;
  int ok ;

  pc = reg[PC_REG] ;
  if ( (pc < 0) || (pc > IADDR_SIZE)  )
      return srIMEM_ERR ;
  reg[PC_REG] = pc + 1 ;
  currentinstruction = iMem[ pc ] ;
  switch (opClass(currentinstruction.iop) )
  { case opclRR :
    
      r = currentinstruction.iarg1 ;
      s = currentinstruction.iarg2 ;
      t = currentinstruction.iarg3 ;
      break;

    case opclRM :
    
      r = currentinstruction.iarg1 ;
      s = currentinstruction.iarg3 ;
      m = currentinstruction.iarg2 + reg[s] ;
      if ( (m < 0) || (m > DADDR_SIZE))
         return srDMEM_ERR ;
      break;

    case opclRA :
    
      r = currentinstruction.iarg1 ;
      s = currentinstruction.iarg3 ;
      m = currentinstruction.iarg2 + reg[s] ;
      break;
  } 

  switch ( currentinstruction.iop)
  { 
    case opHALT :
    
      printf("HALT: %1d,%1d,%1d\n",r,s,t);
      return srHALT ;
      

    case opIN :
    
      do
      { printf("Enter value for IN instruction: ") ;
        fflush (stdin);
        fflush (stdout);
        gets(in_Line);
        lineLen = strlen(in_Line) ;
        inCol = 0;
        ok = getNum();
        if ( ! ok ) printf ("Illegal value\n");
        else reg[r] = num;
      }
      while (! ok);
      break;

    case opOUT :  
      printf ("OUT instruction prints: %d\n", reg[r] ) ;
      break;
    case opADD :  reg[r] = reg[s] + reg[t] ;  break;
    case opSUB :  reg[r] = reg[s] - reg[t] ;  break;
    case opMUL :  reg[r] = reg[s] * reg[t] ;  break;

    case opDIV :
    
      if ( reg[t] != 0 ) reg[r] = reg[s] / reg[t];
      else return srZERODIVIDE ;
      break;

    
    case opLD :    reg[r] = dMem[m] ;  break;
    case opST :    dMem[m] = reg[r] ;  break;

    
    case opLDA :    reg[r] = m ; break;
    case opLDC :    reg[r] = currentinstruction.iarg2 ;   break;
    case opJLT :    if ( reg[r] <  0 ) reg[PC_REG] = m ; break;
    case opJLE :    if ( reg[r] <=  0 ) reg[PC_REG] = m ; break;
    case opJGT :    if ( reg[r] >  0 ) reg[PC_REG] = m ; break;
    case opJGE :    if ( reg[r] >=  0 ) reg[PC_REG] = m ; break;
    case opJEQ :    if ( reg[r] == 0 ) reg[PC_REG] = m ; break;
    case opJNE :    if ( reg[r] != 0 ) reg[PC_REG] = m ; break;

    
  } 
  return srOKAY ;
} 


int doCommand (void)
{ char cmd;
  int stepcnt=0, i;
  int printcnt;
  int stepResult;
  int regNo, loc;
  do
  { printf ("Enter command: ");
    fflush (stdin);
    fflush (stdout);
    gets(in_Line);
    lineLen = strlen(in_Line);
    inCol = 0;
  }
  while (! getWord ());

  cmd = word[0] ;
  switch ( cmd )
  { case 't' :
    
      traceflag = ! traceflag ;
      printf("Tracing now ");
      if ( traceflag ) printf("on.\n"); else printf("off.\n");
      break;

    case 'h' :
    
      printf("Commands are:\n");
      printf("   s(tep <n>      "\
             "Execute n (default 1) TM instructions\n");
      printf("   g(o            "\
             "Execute TM instructions until HALT\n");
      printf("   r(egs          "\
             "Print the contents of the registers\n");
      printf("   i(Mem <b <n>>  "\
             "Print n iMem locations starting at b\n");
      printf("   d(Mem <b <n>>  "\
             "Print n dMem locations starting at b\n");
      printf("   t(race         "\
             "Toggle instruction trace\n");
      printf("   p(rint         "\
             "Toggle print of total instructions executed"\
             " ('go' only)\n");
      printf("   c(lear         "\
             "Reset simulator for new execution of program\n");
      printf("   h(elp          "\
             "Cause this list of commands to be printed\n");
      printf("   q(uit          "\
             "Terminate the simulation\n");
      break;

    case 'p' :
    
      icountflag = ! icountflag ;
      printf("Printing instruction count now ");
      if ( icountflag ) printf("on.\n"); else printf("off.\n");
      break;

    case 's' :
    
      if ( atEOL ())  stepcnt = 1;
      else if ( getNum ())  stepcnt = abs(num);
      else   printf("Step count?\n");
      break;

    case 'g' :   stepcnt = 1 ;     break;

    case 'r' :
    
      for (i = 0; i < NO_REGS; i++)
      { printf("%1d: %4d    ", i,reg[i]);
        if ( (i % 4) == 3 ) printf ("\n");
      }
      break;

    case 'i' :
    
      printcnt = 1 ;
      if ( getNum ())
      { iloc = num ;
        if ( getNum ()) printcnt = num ;
      }
      if ( ! atEOL ())
        printf ("Instruction locations?\n");
      else
      { while ((iloc >= 0) && (iloc < IADDR_SIZE)
                && (printcnt > 0) )
        { writeInstruction(iloc);
          iloc++ ;
          printcnt-- ;
        }
      }
      break;

    case 'd' :
    
      printcnt = 1 ;
      if ( getNum  ())
      { dloc = num ;
        if ( getNum ()) printcnt = num ;
      }
      if ( ! atEOL ())
        printf("Data locations?\n");
      else
      { while ((dloc >= 0) && (dloc < DADDR_SIZE)
                  && (printcnt > 0))
        { printf("%5d: %5d\n",dloc,dMem[dloc]);
          dloc++;
          printcnt--;
        }
      }
      break;

    case 'c' :
    
      iloc = 0;
      dloc = 0;
      stepcnt = 0;
      for (regNo = 0;  regNo < NO_REGS ; regNo++)
            reg[regNo] = 0 ;
      dMem[0] = DADDR_SIZE - 1 ;
      for (loc = 1 ; loc < DADDR_SIZE ; loc++)
            dMem[loc] = 0 ;
      break;

    case 'q' : return FALSE;  

    default : printf("Command %c unknown.\n", cmd); break;
  }  
  stepResult = srOKAY;
  if ( stepcnt > 0 )
  { if ( cmd == 'g' )
    { stepcnt = 0;
      while (stepResult == srOKAY)
      { iloc = reg[PC_REG] ;
        if ( traceflag ) writeInstruction( iloc ) ;
        stepResult = stepTM ();
        stepcnt++;
      }
      if ( icountflag )
        printf("Number of instructions executed = %d\n",stepcnt);
    }
    else
    { while ((stepcnt > 0) && (stepResult == srOKAY))
      { iloc = reg[PC_REG] ;
        if ( traceflag ) writeInstruction( iloc ) ;
        stepResult = stepTM ();
        stepcnt-- ;
      }
    }
    printf( "%s\n",stepResultTab[stepResult] );
  }
  return TRUE;
} 






main( int argc, char * argv[] )
{ if (argc != 2)
  { printf("usage: %s <filename>\n",argv[0]);
    exit(1);
  }
  strcpy(pgmName,argv[1]) ;
  if (strchr (pgmName, '.') == NULL)
     strcat(pgmName,".tm");
  pgm = fopen(pgmName,"r");
  if (pgm == NULL)
  { printf("file '%s' not found\n",pgmName);
    exit(1);
  }

  
  if ( ! readInstructions ())
         exit(1) ;
  
  
  
  printf("TM  simulation (enter h for help)...\n");
  do
     done = ! doCommand ();
  while (! done );
  printf("Simulation done.\n");
  return 0;
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
男男gaygay亚洲| 欧美日韩另类一区| 蜜桃av噜噜一区二区三区小说| 一区二区三区欧美日| 国产精品三级在线观看| 国产视频在线观看一区二区三区 | 国产xxx精品视频大全| 国产做a爰片久久毛片| 精品一区二区三区在线视频| 成人激情图片网| 国产成人午夜精品影院观看视频| 国产尤物一区二区在线| 国产综合一区二区| 国产成人综合亚洲网站| 成人av电影在线| 色综合天天天天做夜夜夜夜做| 欧美无人高清视频在线观看| 欧美日韩在线直播| 91精品国产高清一区二区三区 | 亚洲成a人v欧美综合天堂下载| 午夜国产不卡在线观看视频| 日韩电影在线一区| 麻豆专区一区二区三区四区五区| 国产一区二区美女诱惑| 成人av资源在线观看| 91精品福利视频| 欧美精品乱人伦久久久久久| 日韩三级高清在线| 久久久久99精品一区| 1000精品久久久久久久久| 亚洲精品五月天| 石原莉奈一区二区三区在线观看| 精品一区二区在线视频| 岛国av在线一区| 欧美中文字幕一区二区三区亚洲| 91精品国产色综合久久久蜜香臀| 久久日韩精品一区二区五区| 亚洲视频香蕉人妖| 天天综合色天天综合色h| 精品夜夜嗨av一区二区三区| 99久久精品免费看国产| 欧美裸体一区二区三区| 国产日韩精品一区| 夜夜精品视频一区二区| 久久国产尿小便嘘嘘尿| 91在线一区二区| 91精品国产入口在线| 国产精品色婷婷久久58| 人妖欧美一区二区| jizzjizzjizz欧美| 亚洲美女淫视频| 久久99九九99精品| 91色九色蝌蚪| 精品成a人在线观看| 亚洲靠逼com| 国产在线日韩欧美| 欧美视频在线观看一区二区| 亚洲精品在线观看视频| 亚洲一区二区中文在线| 国产精品18久久久久久久久 | 在线亚洲免费视频| 久久亚洲免费视频| 婷婷中文字幕综合| 99视频精品全部免费在线| 日韩欧美中文字幕精品| 一区二区三区四区高清精品免费观看| 理论片日本一区| 欧洲精品中文字幕| 成人欧美一区二区三区小说| 精品一区二区三区香蕉蜜桃| 欧美中文字幕一区| 国产精品久久午夜| 精品一区二区三区影院在线午夜| 欧美美女网站色| 亚洲老妇xxxxxx| 成人短视频下载| 久久久久国产一区二区三区四区| 日本午夜一本久久久综合| 欧洲人成人精品| 亚洲欧美一区二区三区国产精品| 国产福利一区二区三区视频在线 | 精品午夜一区二区三区在线观看| 欧美日韩亚洲综合| 亚洲欧美电影一区二区| 成熟亚洲日本毛茸茸凸凹| 精品久久久久一区| 另类欧美日韩国产在线| 6080日韩午夜伦伦午夜伦| 亚洲一区二区在线免费看| 91麻豆自制传媒国产之光| 国产精品素人视频| 国产成人免费网站| 久久综合久久99| 久久国产综合精品| 日韩精品一区二区三区四区| 日韩国产欧美三级| 欧美福利一区二区| 五月天国产精品| 欧美伦理视频网站| 日本va欧美va欧美va精品| 欧美高清视频一二三区 | 天堂在线亚洲视频| 欧美日韩黄色一区二区| 亚洲成人综合网站| 欧美高清dvd| 久久精品国产亚洲高清剧情介绍 | 亚洲高清在线精品| 欧美自拍偷拍午夜视频| 亚洲一区视频在线| 欧美精品乱码久久久久久| 亚洲第一av色| 日韩一级大片在线观看| 麻豆专区一区二区三区四区五区| 精品精品国产高清一毛片一天堂| 久久成人av少妇免费| 精品国产免费人成在线观看| 国产久卡久卡久卡久卡视频精品| 国产欧美日韩麻豆91| 成人动漫视频在线| 亚洲人精品一区| 欧美在线视频全部完| 午夜欧美视频在线观看| 欧美一级免费观看| 韩国女主播一区| 国产精品看片你懂得| 97超碰欧美中文字幕| 亚洲人成亚洲人成在线观看图片 | 在线观看日韩一区| 亚洲不卡一区二区三区| 日韩一区二区三区免费看| 九九视频精品免费| 欧美国产欧美综合| 91麻豆国产在线观看| 调教+趴+乳夹+国产+精品| 日韩欧美国产综合在线一区二区三区 | 夜夜爽夜夜爽精品视频| 7777精品伊人久久久大香线蕉经典版下载 | 久久久久久麻豆| 99精品视频一区二区三区| 亚洲综合久久久久| 日韩三级免费观看| 懂色av中文一区二区三区| 有码一区二区三区| 亚洲理论在线观看| 日韩视频在线一区二区| 国产91色综合久久免费分享| 亚洲精品国产一区二区三区四区在线| 欧美日韩色一区| 国产在线一区二区| 一二三四社区欧美黄| 精品福利一区二区三区| 91蜜桃视频在线| 轻轻草成人在线| 国产精品三级久久久久三级| 91麻豆精品国产91| 99久久免费精品高清特色大片| 偷窥国产亚洲免费视频| 日本一区二区动态图| 欧美丰满美乳xxx高潮www| 国产.欧美.日韩| 日韩在线一区二区| 最新成人av在线| 精品国产乱码久久| 欧美在线短视频| 懂色av一区二区三区免费观看| 午夜精品久久久久久| 国产精品乱人伦| 亚洲精品在线三区| 欧美日韩中文精品| 北条麻妃国产九九精品视频| 蜜桃视频一区二区三区在线观看| 国产精品久久久久久亚洲伦| 日韩美女一区二区三区四区| 欧美主播一区二区三区| 成人va在线观看| 国内成人免费视频| 亚洲国产三级在线| 国产精品美女久久久久aⅴ| 日韩欧美另类在线| 欧美三级中文字幕在线观看| a级精品国产片在线观看| 另类的小说在线视频另类成人小视频在线 | 欧美日韩综合在线免费观看| 福利一区在线观看| 久久国产乱子精品免费女| 亚洲图片欧美色图| 亚洲色图19p| 国产精品区一区二区三| 久久综合一区二区| 日韩一区二区三区四区| 欧洲国内综合视频| av亚洲精华国产精华精| 国产99久久久国产精品潘金网站| 久久99国产精品麻豆| 日av在线不卡| 蜜臀av一区二区在线免费观看| 午夜精品久久久久久久久久 | 菠萝蜜视频在线观看一区| 国产一区二区主播在线| 精品一区二区影视|