- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
设计任务
PL/0语言解读
PL/0语言增加C语言形式的/*……*/的注释
给PL/0语言增加输入输出语言
给PL/0语言增加布尔类型,并且布尔类型的表达式按短路方式计算。
设计思想和实现方法
1、PL/0语言增加C语言形式的/*……*/的注释
在getch函数中,如果找到’/*’字符串,则将ll - 2的值保存到lbuffer中,将szFlag标记,继续通过getc函数从文件中读取字符,并赋值到line数组中(这里的字符都是注释),直到我们从文件中读取到’*/’字符串,我们将szFlag标记置回原值,并将lbuffer中的值赋给ll,然后我们找到的‘\n’,则退出这次while循环取值,这样就在PL/0语言中实现了C语言形式的/*……*/的注释。
实现代码:
2、给PL/0语言增加输入输出语言
首先在word数组和wsym数组中添加read,write关键字和readsym,writesym宏,然后再statement函数中添加read和write关键字的处理if-else子分支。
在处理处理read关键字函数中,首先同getsym函数取得下个字符的sym,如果是lparen(代表左括号),如果不是,则输出响应的错误代码,在通过getsym函数取得下个标记符,并判断类型,如果sym是ident(变量),找到变量在table中的位置,判断table中的类型,生成代码,然后getsym继续去标识符。
处理write函数的方式跟read函数相似。
3、给PL/0语言增加布尔类型,并且布尔类型的表达式按短路方式计算。
首先爱word数组中和wsym数组中添加true,false,boolean关键字和truesym,falsesym,booleansym宏,并在factor函数中添加处理boolean的if-else子分支,在分支中通过判断值得内容,并生成相应的代码。
程序说明
添加注释
while((!feof(infile)))// ((ch=getc(infile))!=\n)
{
ch=getc(infile);
if (szFlag == y)
{
if (ch ==\n)
{
break;
}
}
printf(%c, ch);
ll = ll + 1;
line[ll] = ch;
if ((ll = 1 ) (line[ll - 1] == /) line[ll] == *)
{
lbuffer = ll - 2;
szFlag = n;
}
if ((ll = 1) (line[ll - 1] == *) (line[ll] == /))
{
ll = lbuffer;
szFlag = y;
}
}
添加输入输出
else if (sym==writesym)
{
getsym();
if(sym==lparen)
{
do
{
getsym();
if (sym==ident)
{
i=position(id);
if(i==0)
{
error(11);
}
else if(table[i].kind!=variable) // assignment to non-variable
{
error(12); i=0;
}
gen(opr, 0, 15);
getsym();
}
else
{
error(8);
}
}while(sym == comma);
if (sym!=rparen)
{
error(22);
}
getsym();
}
}
else if(sym==readsym)
{
getsym();
if (sym==lparen)
{
do
{
getsym();
if (sym==ident)
{
i=position(id);
if(i==0)
{
error(11);
}
else if(table[i].kind!=variable) // assignment to non-variable
{
error(12); i=0;
}
gen(opr, 0, 14);
if
您可能关注的文档
- MANAGEMENT INFORMATION SYSTEMS (MAN2092)教学:ExampleMark74.pdf
- MANAGEMENT INFORMATION SYSTEMS (MAN2092)教学:ERP_Hershey.pdf
- MANAGEMENT INFORMATION SYSTEMS (MAN2092)教学:Lecture01.pptx
- MANAGEMENT INFORMATION SYSTEMS (MAN2092)教学:Lecture03.pptx
- MANAGEMENT INFORMATION SYSTEMS (MAN2092)教学:Lecture02.pptx
- MANAGEMENT INFORMATION SYSTEMS (MAN2092)教学:Lecture07.pdf
- MANAGEMENT INFORMATION SYSTEMS (MAN2092)教学:Lecture08.pdf
- MANAGEMENT INFORMATION SYSTEMS (MAN2092)教学:Lecture09.pdf
- MANAGEMENT INFORMATION SYSTEMS (MAN2092)教学:Lecture11.pdf
- MANAGEMENT INFORMATION SYSTEMS (MAN2092)教学:Lecture10.pdf
- 2025年无人机低空医疗物资投放社会效益报告.docx
- 2025年再生塑料行业包装回收利用产业链重构研究.docx
- 《AI眼镜周边产品市场机遇:2025年终端销售与需求增长洞察》.docx
- 2025年坚果加工行业深加工技术突破与市场拓展策略报告.docx
- 2025年通信芯片行业技术竞争与未来趋势报告.docx
- 《2025年生鲜电商配送冷链事故分析与预防措施》.docx
- 《商业航天融资新趋势2025民营卫星企业资本涌入估值分析市场动态》.docx
- 2025年能源绿色健康行业创新技术与市场应用报告.docx
- 2025年无人机低空医疗救援通信方案分析报告.docx
- 2025年烹饪机器人行业市场集中度分析报告.docx
原创力文档


文档评论(0)