标签:for i++ ret nbsp details 运算符 返回 保留 switch
词法分析程序(Lexical Analyzer)要求:
- 从左至右扫描构成源程序的字符流
- 识别出有词法意义的单词(Lexemes)
- 返回单词记录(单词类别,单词本身)
- 滤掉空格
- 跳过注释
- 发现词法错误
程序结构:
输入:字符流(什么输入方式,什么数据结构保存)
处理:
–遍历(什么遍历方式)
–词法规则
输出:单词流(什么输出形式)
–二元组
单词类别:
1.标识符(10)
2.无符号数(11)
3.保留字(一词一码)
4.运算符(一词一码)
5.界符(一词一码)
单词符号 |
种别码 |
单词符号 |
种别码 |
begin |
1 |
: |
17 |
if |
2 |
:= |
18 |
then |
3 |
< |
20 |
while |
4 |
<= |
21 |
do |
5 |
<> |
22 |
end |
6 |
> |
23 |
l(l|d)* |
10 |
>= |
24 |
dd* |
11 |
= |
25 |
+ |
13 |
; |
26 |
- |
14 |
( |
27 |
* |
15 |
) |
28 |
/ |
16 |
# |
0 |
#include <stdio.h> #include <string.h> #define max 200 char pro[max],lin[20]; int n,i,syn; char *word[6]={ "begin", "if" , "then", "while", "do" ,"end" }; char ch; void scaner(){ int j=0; for(n=0;n<20;n++) lin[n]=NULL; ch=pro[i++]; while (ch==‘ ‘) ch=pro[i++]; if((ch>=‘A‘&&ch<=‘Z‘)||(ch>=‘a‘&&ch<=‘z‘)||(ch>=48&&ch<=57)) { if((ch>=‘A‘&&ch<=‘Z‘)||(ch>=‘a‘&&ch<=‘z‘)){ lin[j++]=ch; ch=pro[i++]; while((ch>=‘A‘&&ch<=‘Z‘)||(ch>=‘a‘&&ch<=‘z‘)||(ch>=48&&ch<=57)) { lin[j++]=ch; ch=pro[i++]; } lin[j]=‘\0‘; i--; syn=10; for (n=0;n<6;n++) if (strcmp(lin,word[n])==0) { syn=n+1; break; } } else { while(ch>=48&&ch<=57) { lin[j++]=ch; ch=pro[i++]; } i--; lin[j]=‘\0‘; syn=11; } } else { if(ch==‘<‘) { lin[j++]=ch; ch=pro[i++]; if(ch==‘>‘) { syn=21; lin[j++]=ch; lin[j]=‘\0‘; } else if(ch==‘=‘) { syn=22; lin[j++]=ch; lin[j]=‘\0‘; } else { syn=20; lin[j]=‘\0‘; i--; } } else if (ch==‘>‘) { lin[j++]=ch; ch=pro[i++]; if(ch==‘=‘) { syn=24; lin[j++]=ch; lin[j]=‘\0‘; } else{ syn=23; lin[j]=‘\0‘; i--; } } else if(ch==‘:‘) { lin[j++]=ch; ch=pro[i++]; if(ch==‘=‘) { syn=18; lin[j++]=ch; lin[j]=‘\0‘; } else { syn=17; lin[j]=‘\0‘; i--; } } else if(ch==‘+‘) { syn=13; lin[j++]=ch; lin[j]=‘\0‘; } else if (ch==‘-‘) { syn=14; lin[j++]=ch; lin[j]=‘\0‘; } else if (ch==‘*‘) { syn=16; lin[j++]=ch; lin[j]=‘\0‘; } else if (ch==‘/‘) { syn=16; lin[j++]=ch; lin[j]=‘\0‘; } else if (ch==‘=‘) { syn=25; lin[j++]=ch; lin[j]=‘\0‘; } else if (ch==‘;‘) { syn=26; lin[j++]=ch; lin[j]=‘\0‘; } else if (ch==‘(‘) { syn=27; lin[j++]=ch; lin[j]=‘\0‘; } else if (ch==‘)‘) { syn=28; lin[j++]=ch; lin[j]=‘\0‘; } else if (ch==‘#‘) { syn=0; lin[j++]=ch; lin[j]=‘\0‘; } else syn=-1; } return ; } void read() { FILE *fp; int k; fp=fopen("shi_yan.txt","r"); for (k=0;k<max-1;k++) { fscanf(fp,"%c",&pro[k]); } pro[k]=‘\0‘; fclose(fp); } int main(void) { int i=0; printf("**************************************************************************\n"); printf("*********************************种别编码*********************************\n"); printf("**************************************************************************\n"); printf("(1,begin) (2,if) (3,then) (4,while) (5,do)\n"); printf("(6,end) (10,基本标示符) (11,数字) (13,+) (14,-)\n"); printf("(15,*) (16,/) (17,:) (18,:=) (20,<)\n"); printf("(21,<>) (22,<=) (23,>) (24,>=) (25,=)\n"); printf("(26,;) (27,() (28,)) (0,#)\n"); read(); printf("\n\n读入的字符串如下:\n\n"); puts(pro); printf( "\n词法分析结果如下:\n" ); printf( "\n" ); do { scaner(); switch(syn) { case 11: printf("(%d,%s)\n",syn,lin); break; case -1: printf("错误符号\n"); break; default: printf("(%d,%s)\n",syn,lin); } } while (syn!=0); printf( "\n词法分析结束\n" ); scanf("%c",&i); return 0; }
(代码知识不太精通)
参考于:https://blog.csdn.net/xyy410874116/article/details/6397549 https://blog.csdn.net/fybshy/article/details/31826321
标签:for i++ ret nbsp details 运算符 返回 保留 switch
原文地址:https://www.cnblogs.com/jinwhy/p/11655576.html