scaner() { sum=0; for(m=0;m<8;m++)token[m++]=NULL; m=0; ch=prog[p++]; while(ch==' ')ch=prog[p++]; //扫描到字符 if(((ch<='z')&&(ch>='a'))||((ch<='Z')&&(ch>='A'))) //扫描到小写字母或者大写字母或者0-9数字 { while(((ch<='z')&&(ch>='a'))||((ch<='Z')&&(ch>='A'))||((ch>='0')&&(ch<='9'))) {token[m++]=ch; ch=prog[p++]; } p--; syn=10; token[m++]='\0'; for(n=0;n<6;n++) if(strcmp(token,rwtab[n])==0) { syn=n+1; break; } } else if((ch>='0')&&(ch<='9')) { while((ch>='0')&&(ch<='9')) { sum=sum*10+ch-'0'; ch=prog[p++]; } p--; syn=11; } else switch(ch) { case '<':m=0; ch=prog[p++]; if(ch=='>') { syn=21; } else if(ch=='=') { syn=22; } else { syn=20; p--; } break; case '>':m=0; ch=prog[p++]; if(ch=='=') { syn=24; } else { syn=23; p--; } break; case ':':m=0; ch=prog[p++]; if(ch=='=') { syn=18; } else { syn=17; p--; } break; case '+': syn=13; break; case '-': syn=14; break; case '*': syn=15;break; case '/': syn=16;break; case '(': syn=27;break; case ')': syn=28;break; case '=': syn=25;break; case ';': syn=26;break; case '#': syn=0;break; default: syn=-1;break; } }每行代码注释
时间: 2023-10-25 18:06:40 浏览: 121
扫描器代码
4星 · 用户满意度95%
这是一个名为 `scaner()` 的函数,用于词法分析,对输入的字符串进行扫描和解析。
首先将变量 `sum` 初始化为0,将 `token` 数组中的每个元素都赋值为 `NULL`,将变量 `m` 初始化为0,然后读取输入字符串中的字符,跳过空格。如果扫描到小写字母、大写字母或者数字,则将其加入到 `token` 数组中,直到遇到非字母非数字的字符。如果 `token` 中的字符串与关键字表中的关键字匹配,则将变量 `syn` 赋值为关键字的编号加1,否则 `syn` 赋值为10。
如果扫描到数字,则将其解析成整数并将其赋值给变量 `sum`,将 `syn` 赋值为11。
如果扫描到其他字符,则根据不同的字符进行判断并设置 `syn` 的值。
最后返回 `syn` 的值,表示识别出的单词类型。
阅读全文