基本信息
源码名称:大学编译实验一 --词法分析器 (C++版)
源码大小:7.01KB
文件格式:.cpp
开发语言:C/C++
更新时间:2021-05-07
   友情提示:(无需注册或充值,赞助后即可获取资源下载链接)

     嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300

本次赞助数额为: 2 元 
   源码介绍


实验一:设计SAMPLE语言的词法分析器

检查要求:

a)启动程序后,先输出作者姓名、班级、学号(可用汉语、英语或拼音);

b)请求输入测试程序名,键入程序名后自动开始词法分析并输出结果;

c)输出结果为单词的二元式序列(样式见样板输出12);

d)要求能发现下列词法错误和指出错误性质和位置:

非法字符,即不是SAMPLE字符集的符号;

字符常数缺右边的单引号(字符常数要求左、右边用单引号界定,不能跨行);

注释部分缺右边的界符*/(注释要求左右边分别用/**/界定,不能跨行);

发现错误后要能够继续编译下去,不能只报一个错误;



   (部分代码样例)

仅有一个 compiler.cpp 文件, 不提供TEST 文件。

public: bool isNumber(char ch){ if(ch>=48&&ch<58) return true; else return false; } bool isLetter(char ch){ if((ch>=65&&ch<=90)||(ch>=97&&ch<=122)||(ch==337)) return true; else return false; } bool isSingle(char ch){ for(int i=0;i<16;i ){ if(singleDelimiter[i]==ch) return true; } return false; } bool isDouble(string word){ for(int i=0;i<7;i ){ if(doubleDelimiter[i]==word) return true; } return false; }  bool isKeyword(string word){ for(int i=0;i<35;i ){ if(keyword[i]==word) return true; } return false; } int getKeyWordCode(string word){ int index=0; for(int i=0;i<35;i ){ if(keyword[i]==word) index=i 1; } return index; }