130242014018-郑志良-第2次实验
一、實(shí)驗(yàn)?zāi)康?/p>
1.熟悉體系結(jié)構(gòu)的風(fēng)格的概念
2.理解和應(yīng)用管道過濾器型的風(fēng)格。
3、理解解釋器的原理
4、理解編譯器模型
二、實(shí)驗(yàn)環(huán)境
硬件:?
軟件:Python或任何一種自己喜歡的語言
三、實(shí)驗(yàn)內(nèi)容
1、實(shí)現(xiàn)“四則運(yùn)算”的簡易翻譯器。
結(jié)果要求:
1)實(shí)現(xiàn)加減乘除四則運(yùn)算,允許同時(shí)又多個(gè)操作數(shù),如:2+3*5-6 結(jié)果是11
2)被操作數(shù)為整數(shù),整數(shù)可以有多位
3)處理空格
4)輸入錯(cuò)誤顯示錯(cuò)誤提示,并返回命令狀態(tài)“CALC”
? 圖1 ? ?實(shí)驗(yàn)結(jié)果示例
加強(qiáng)練習(xí):
1、有能力的同學(xué),可以嘗試實(shí)現(xiàn)賦值語句,例如x=2+3*5-6,返回x=11。(注意:要實(shí)現(xiàn)解釋器的功能,而不是只是顯示)
2、嘗試實(shí)現(xiàn)自增和自減符號,例如x++?
2、采用管道-過濾器(Pipes and Filters)風(fēng)格實(shí)現(xiàn)解釋器
? ? ? ? ? ? ? ? ? ? ? ? 圖2 ?管道-過濾器風(fēng)格
? ? ? ? ? ? ? ? ? ? ?圖 3 ?編譯器模型示意圖
本實(shí)驗(yàn),實(shí)現(xiàn)的是詞法分析和語法分析兩個(gè)部分。
四、實(shí)驗(yàn)步驟:
? ??#include "stdio.h"
#include "stdlib.h"
#include "ctype.h"
int n=0;
char record[20];
float product();
float change();
float muli()
{
? ? float summ;
? ? summ=product();
? ? while(record[n]=='-'||record[n]=='+')
? ?{
??switch(record[n])
? ? ? {
? ? ? ? case '+':n++;summ+=product();break;
? ? ? ? case '-':n++;summ-=product();break;
? ? ? ?}
? ? }
?return summ;
}
float product()
{
?float sump;
?sump=change();
?while(record[n]=='*'||record[n]=='/')
?{
??switch(record[n])
??{
???case '*':n++;sump*=change();break;
???case '/':n++;sump/=change();break;
??}
?}
?return sump;
}
float change()
{
?float sumc;
?char? rec[20],i=0;
?if(record[n]=='(')
?{
??n++;
??sumc=muli();
?}
?if(record[n]==')')
? n++;
? while(isdigit(record[n])||record[n]=='.')
? {
? ?while(isdigit(record[n])||record[n]=='.')
? ??rec[i++]=record[n++];
? ??rec[i]='\0';
? ??sumc=atof(rec);
? }
? return? sumc;?
}
void main()
{
?while(1)
?{
?n=0;
?scanf("%s",record);
?printf("%s=%g\n",record,muli());
?}??
}
?
對應(yīng)結(jié)構(gòu)圖:?
五、實(shí)驗(yàn)總結(jié)
?
轉(zhuǎn)載于:https://www.cnblogs.com/zzl1/p/7748750.html
創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)總結(jié)
以上是生活随笔為你收集整理的130242014018-郑志良-第2次实验的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 《纸嫁衣4》中元节上线首日就无法进入游戏
- 下一篇: mybatis一级缓存二级缓存