




下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、 詞法分析器實(shí)驗(yàn)報(bào)告實(shí)驗(yàn)?zāi)康模涸O(shè)計(jì)、編制、調(diào)試一個(gè)詞法分析子程序識別單詞,加深對詞法分析原理的理解。功能描述:該程序要實(shí)現(xiàn)的是一個(gè)讀單詞過程,從輸入的源程序中,識別出各個(gè)具有獨(dú)立意義的單詞,即基本保留字、標(biāo)識符、常數(shù)、運(yùn)算符、分隔符五大類。并依次輸出各個(gè)單詞的部編碼及單詞符號自身值。(遇到錯(cuò)誤時(shí)可顯示“Error!”,然后跳過錯(cuò)誤部分繼續(xù)進(jìn)行)設(shè)計(jì)思想:設(shè)計(jì)該詞法分析器的過程中雖然沒有實(shí)際將所有的狀態(tài)轉(zhuǎn)移表建立出來,但是所用的思想是根據(jù)狀態(tài)轉(zhuǎn)移表實(shí)現(xiàn)對單詞的識別。首先構(gòu)造一個(gè)保留字表,然后,每輸入一個(gè)字符就檢測應(yīng)該進(jìn)入什么狀態(tài),并將該字符連接到d串后繼續(xù)輸入,如此循環(huán),最后根據(jù)所在的接受狀態(tài)以
2、及保留字表識別單詞。符號表:記號類別屬性值ws-const保留字1var保留字1call保留字1begin保留字1if保留字1while保留字1do保留字1odd保留字1end保留字1then保留字1procedure保留字1=運(yùn)算符2<運(yùn)算符2<=運(yùn)算符2<>運(yùn)算符2>運(yùn)算符2>=運(yùn)算符2*運(yùn)算符2+運(yùn)算符2-運(yùn)算符2/運(yùn)算符2:=運(yùn)算符2ident標(biāo)識符3number常數(shù)4(分隔符5)分隔符5;分隔符5,分隔符5.分隔符5狀態(tài)轉(zhuǎn)換圖:標(biāo)識符及保留字:Startletterletter or digittnumber:70214365startotherd
3、igit.digitE+ | -digitdigitdigitdigitEdigit*otherother關(guān)系操作符:start<other= (<=, 2)>=other>=* (<>, 2) (<,2) (=, 2) (>=, 2)(>, 2):=(:=,2)分隔符:start;(),.( ; ,5)( (,5)( ),5)( , ,5)( . ,5)算術(shù)運(yùn)算符:start+-*/( + ,2)( -,2)( *,2)( / ,2)使用環(huán)境:Windows xp下的visual c+6.0程序測試:input1 :int a,b;a=b
4、+2;input2:while(a>=0)do7x=x+6.7E+23;end;input3:begin:x:=9if x>0 then x:=x+1;while a:=0 dob:=2*x/3,c:=a;end;9 / 9output1:3,int3,a5,3,b5,;3,a2,=3,b2,+4,25,;output2:1,while5,(3,a2,>=4,05,)1,doerror line 32,=3,x2,+4,6.7E+235,;1,end5,;output3:1,beginerror line 13,x2,:=4,91,if3,x2,>4,01,then3,
5、x2,:=3,x2,+4,15,;1,while3,a2,:=4,01,do3,b2,:=4,22,*3,x2,/4,35,3,c2,:=3,a5,;1,end5,;測試結(jié)果與預(yù)期結(jié)果一致源程序代碼:#include<stdio.h>#include<string.h>void main()int i=0,j,k=0,state=1,f=0,linenum=1;char a1110="const","var","call","begin","if","while
6、","do","odd","end","then","procedure"char b,d40="0" freopen("input.txt","r",stdin); freopen("output.txt","w",stdout); b=getchar(); while(b!=EOF)/*判斷所輸入字符是否為結(jié)束符*/if(b=' '|b='n'|b=&
7、#39;t')/*濾過空格、換行等分隔符號*/ if(b='n') linenum+;b=getchar();else if(b>='a'&&b<='z')|(b>='A'&&b<='Z')/*識別標(biāo)識符以及保留字*/di+=b; b=getchar();while(b>='a'&&b<='z')|(b>='A'&&b<='Z')|(
8、b>='0'&&b<='9') di+=b;b=getchar();for(j=0;j<11;j+)/*查詢保留字表確定該單詞是否是保留字*/ if(strcmp(d,aj)=0) printf("1,%sn",d); k=1; break;if(k=0)/*在保留字表中沒有查到該單詞,是標(biāo)識符*/ printf("3,%sn",d);for(j=0;j<=i;j+)dj='0' i=0;k=0;else if(b>='0'&&b
9、<='9')/*識別常數(shù)*/ di+=b; b=getchar(); while(f!=1) switch (state) case 1: if(b>='0'&&b<='9') state=1; di+=b; b=getchar(); else if(b='.') state=2;di+=b;b=getchar(); else if(b='E') state=4;di+=b;b=getchar(); else state=7; break; case 2: if(b>=
10、9;0'&&b<='9') state=3; di+=b; b=getchar(); else state=8; break; case 3: if(b>='0'&&b<='9') state=3; di+=b; b=getchar(); else if(b='E') state=4;di+=b;b=getchar(); else state=7; break; case 4: if(b='+'|b='-') state=5;di+=b;b=
11、getchar(); else if(b>='0'&&b<='9') state=6;di+=b;b=getchar(); else state=8; break; case 5: if(b>='0'&&b<='9') state=6;di+=b;b=getchar(); else state=8; break; case 6: if(b>='0'&&b<='9') state=6;di+=b;b=getchar()
12、; else state=7; break; case 7: f=1;break; case 8: f=1;break; if(state=7&&(b<'a'|b>'z')&&(b<'A'|b>'Z') printf("4,%sn",d); else if(state=7&&(b>='a'&&b<='z')|(b>='A'&&b<=
13、9;Z')/*數(shù)字后接字母的出錯(cuò)控制*/ while(b>='a'&&b<='z')|(b>='A'&&b<='Z') di+=b; b=getchar(); printf("error line %dn",linenum); else printf("error line %dn",linenum); for(j=0;j<=i;j+)dj='0' i=0; f=0; state=1;else if(b=&
14、#39;<')/*識別'<'、'<='和'<>'*/ di+=b; b=getchar(); if(b='='|b='>') di+=b; b=getchar(); printf("2,%sn",d); for(j=0;j<=i;j+)dj='0' i=0; else printf("2,%sn",d); for(j=0;j<=i;j+)dj='0'i=0; else if(b='
15、>')/*識別'>'和'>='*/ di+=b; b=getchar(); if(b='=') di+=b; b=getchar(); printf("2,%sn",d); for(j=0;j<=i;j+)dj='0' i=0; else printf("2,%sn",d); for(j=0;j<=i;j+)dj='0'i=0; else if(b=':')/*識別':='*/ di+=b; b=getch
16、ar(); if(b='=') di+=b; b=getchar(); printf("2,%sn",d); else printf("error line %dn",linenum); for(j=0;j<=i;j+)dj='0' i=0; else if(b='*'|b='+'|b='-'|b='/'|b='=')/*識別運(yùn)算符*/ printf("2,%cn",b); b=getchar(); else if(b='('|b=')'|b=','|b
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025商場租賃合同樣本
- 2025二手車買賣交易合同
- 2025租房合同 年付協(xié)議
- 廣東省東莞市2024~2025學(xué)年 高二下冊第一次月考數(shù)學(xué)試卷附解析
- 2025年中考語文(長沙用)課件:復(fù)習(xí)任務(wù)群6 文學(xué)、文化常識
- 中國共產(chǎn)黨執(zhí)政:歷史和人民的選擇教學(xué)課件
- 2024年四川公務(wù)員行測(B類)真題及答案
- 志 委托編纂?yún)f(xié)議
- 2025年醫(yī)藥儲運(yùn)部試題
- 超聲激勵(lì)下生物組織熱與應(yīng)力損傷的研究
- 安全用電及觸電急救知識
- 遼寧省沈陽126中學(xué)2025屆中考生物考前最后一卷含解析
- 2024年05月恒豐銀行上海分行零售金融部社會招聘(4人)筆試歷年參考題庫附帶答案詳解
- 專題22+常見的地貌類型-高考地理+二輪復(fù)習(xí)課件
- 精神衛(wèi)生機(jī)構(gòu)污水處理方案
- 【MOOC】模式識別-青島大學(xué) 中國大學(xué)慕課MOOC答案
- 延長石油集團(tuán)招聘筆試
- 液化氣站動(dòng)火安全管理制度(4篇)
- 《飛機(jī)種類及結(jié)構(gòu)》課件
- 透析患者貧血的護(hù)理
- 【MOOC】電子線路設(shè)計(jì)、測試與實(shí)驗(yàn)(二)-華中科技大學(xué) 中國大學(xué)慕課MOOC答案
評論
0/150
提交評論