




版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、輔導(dǎo)教師 成績(jī) 實(shí)驗(yàn)日期實(shí)驗(yàn)時(shí)間1實(shí)驗(yàn)名稱 :詞法分析器的設(shè)計(jì)與實(shí)現(xiàn)2、實(shí)驗(yàn)?zāi)康模?)掌握C語(yǔ)言單詞符號(hào)的劃分、正規(guī)式、狀態(tài)轉(zhuǎn)換圖及詞法分析器的實(shí)現(xiàn)。(2)掌握詞法分析程序的作用。3、實(shí)驗(yàn)要求(1)對(duì)任給的一個(gè)C語(yǔ)言源程序,能夠?yàn)V掉空格、回車換行符、tab鍵及注釋。(2)識(shí)別各類單詞符號(hào),如關(guān)鍵字、標(biāo)識(shí)符、運(yùn)算符、常數(shù)、界符,結(jié)果以二元式形式輸出,并構(gòu)造符號(hào)表。(3)輸出有詞法錯(cuò)誤的單詞及所在行號(hào)。4、實(shí)驗(yàn)原理根據(jù)掃描到的單詞符號(hào)的第一個(gè)字符的種類,分別轉(zhuǎn)到相應(yīng)的程序進(jìn)行處理。這些程序的功能就是識(shí)別以相應(yīng)字符開頭的各類單詞符號(hào)。5、實(shí)驗(yàn)步驟(1)根據(jù)C語(yǔ)言各類單詞的正規(guī)式,構(gòu)造能識(shí)別各類單詞的
2、狀態(tài)轉(zhuǎn)換圖。(2)根據(jù)狀態(tài)轉(zhuǎn)換圖,構(gòu)造識(shí)別各類單詞的詞法分析器。6、文法及狀態(tài)轉(zhuǎn)換圖7、程序流程圖8、關(guān)鍵代碼#include<stdio.h>#include<string.h>#include<iostream.h>#include<stdlib.h>char prog80,token8;char ch;int syn,p,m=0,n,row,sum=0;char *rwtab6="for","if","then","but","do",&qu
3、ot;end"void scaner() /*共分為三大塊,分別是標(biāo)示符、數(shù)字、符號(hào),對(duì)應(yīng)下面的 if else if 和 else */ for(n=0;n<8;n+) tokenn=NULL; ch=progp+; while(ch=' ') ch=progp; p+; if(ch>='a'&&ch<='z')|(ch>='A'&&ch<='Z') /可能是標(biāo)示符或者變量名 m=0;while(ch>='0'&
4、&ch<='9')|(ch>='a'&&ch<='z')|(ch>='A'&&ch<='Z') tokenm+=ch; ch=progp+; tokenm+='0' p-; syn=10; for(n=0;n<6;n+) /將識(shí)別出來(lái)的字符和已定義的標(biāo)示符作比較, if(strcmp(token,rwtabn)=0) syn=n+1; break; else if(ch>='0'&&ch
5、<='9') /數(shù)字 sum=0; while(ch>='0'&&ch<='9') sum=sum*10+ch-'0' ch=progp+; p-; syn=11; if(sum>32767) syn=-1; else switch(ch) /其他字符 case'<':m=0;tokenm+=ch; ch=progp+; if(ch='>') syn=21; tokenm+=ch; else if(ch='=') syn=22; t
6、okenm+=ch; else syn=23; p-; break; case'>':m=0;tokenm+=ch; ch=progp+; if(ch='=') syn=24; tokenm+=ch; else syn=20; p-; break; case':':m=0;tokenm+=ch; ch=progp+; if(ch='=') syn=18; tokenm+=ch; else syn=17; p-; break; case'*':syn=13;token0=ch;break; case'/
7、':syn=14;token0=ch;break; case'+':syn=15;token0=ch;break; case'-':syn=16;token0=ch;break; case'=':syn=25;token0=ch;break; case'':syn=26;token0=ch;break; case'(':syn=27;token0=ch;break; case')':syn=28;token0=ch;break; case'#':syn=0;token0=ch
8、;break; case'n':syn=-2;break; default: syn=-1;break; int main() p=0; row=1; cout<<"Please input string:"<<endl; do cin.get(ch); progp+=ch; while(ch!='#'); p=0; do scaner(); switch(syn) case 11: cout<<"("<<syn<<","<<sum
9、<<")"<<endl; break; case -1: cout<<"Error in row "<<row<<"!"<<endl; break; case -2: row=row+;break; default: cout<<"("<<syn<<","<<token<<")"<<endl;break; while (syn!=0)
10、; system("pause");9、測(cè)試及結(jié)果(截圖)10、心得通過這次實(shí)驗(yàn)的練習(xí),使我加深對(duì)詞法分析原理的理解,熟悉了構(gòu)造詞法分析程序的手工方式的相關(guān)原理。掌握了C語(yǔ)言單詞符號(hào)的劃分、正規(guī)式、狀態(tài)轉(zhuǎn)換圖及詞法分析器的實(shí)現(xiàn)。以及掌握詞法分析程序的作用。輔導(dǎo)教師 成績(jī) 實(shí)驗(yàn)日期實(shí)驗(yàn)時(shí)間1實(shí)驗(yàn)名稱 算符優(yōu)先語(yǔ)法分析2、實(shí)驗(yàn)?zāi)康模?)掌握算符優(yōu)先分析方法;(2)通過設(shè)計(jì)、編制、調(diào)試一個(gè)算術(shù)表達(dá)式的語(yǔ)法分析程序,加深對(duì)語(yǔ)法分析原理的理解。3、實(shí)驗(yàn)要求(1)實(shí)驗(yàn)內(nèi)容: 設(shè)計(jì)及實(shí)現(xiàn)計(jì)算表達(dá)式的計(jì)算器。 表達(dá)式中可包含+、-、*、/、(、)等運(yùn)算符。(2)實(shí)驗(yàn)要求:對(duì)已給的一個(gè)算術(shù)表達(dá)式,能夠檢查有無(wú)語(yǔ)法錯(cuò)誤,并指定出錯(cuò)位置。寫出算術(shù)表達(dá)式的符合分析方
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度商業(yè)綜合體水電費(fèi)結(jié)算與管理合同
- 2025年度股權(quán)收益權(quán)轉(zhuǎn)讓與回購(gòu)合同模板
- 二零二五年度新材料勞動(dòng)合同法條知識(shí)產(chǎn)權(quán)保護(hù)合同
- 二零二五年度金融產(chǎn)品銷售業(yè)務(wù)員傭金分配協(xié)議
- 二零二五年度魚塘使用權(quán)及養(yǎng)殖廢棄物處理轉(zhuǎn)讓合同
- 四川省通信產(chǎn)業(yè)服務(wù)有限公司成都市分公司招聘筆試參考題庫(kù)附帶答案詳解
- 2025重慶九洲隆瓴科技有限公司招聘軟件技術(shù)員等崗位30人筆試參考題庫(kù)附帶答案詳解
- 校園安全知識(shí)培訓(xùn)課件
- 2025浙江溫州市白鹿人才科技發(fā)展有限公司招聘項(xiàng)目部工作人員2人筆試參考題庫(kù)附帶答案詳解
- 2025江西吉安市創(chuàng)新投資集團(tuán)有限公司面向社會(huì)招聘臨聘人員1人筆試參考題庫(kù)附帶答案詳解
- 2024年保密教育培訓(xùn)考試(題目和答案)
- 國(guó)家級(jí)重點(diǎn)??圃u(píng)分標(biāo)準(zhǔn)
- 遼寧省部分高中2023-2024學(xué)年高一下學(xué)期4月月考化學(xué)試題
- 2024智慧風(fēng)電智能運(yùn)檢技術(shù)風(fēng)機(jī)葉片巡檢機(jī)器人
- 電工技術(shù)基礎(chǔ)與技能 第4版 課件全套(姚錦衛(wèi))第1-7章 電能與安全用電- 戶內(nèi)開關(guān)箱的安裝與調(diào)試
- 2024年歐洲電動(dòng)汽車充電站和充電樁市場(chǎng)主要企業(yè)市場(chǎng)占有率及排名
- 熟練掌握客服常用工具的使用課件
- 分析化學(xué)試題(附答案)
- JT-T-325-2018營(yíng)運(yùn)客運(yùn)類型劃分及等級(jí)評(píng)定
- 小兒腸套疊護(hù)理查房
- 2024年常州工業(yè)職業(yè)技術(shù)學(xué)院?jiǎn)握新殬I(yè)技能測(cè)試題庫(kù)附答案
評(píng)論
0/150
提交評(píng)論