版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)
文檔簡介
1、精品詞法分析器實驗報告詞法分析器設(shè)計一、實驗?zāi)康模簩語言的一個子集設(shè)計并實現(xiàn)一個簡單的詞法分析器,掌握利用狀態(tài)轉(zhuǎn)換圖設(shè)計詞法分析器的基本方法。利用該詞法分析器完成對源程序字符串的詞法分析。輸出形式是源程序的單詞符號二元式的代碼,并保存到文件中。二、實驗內(nèi)容:1. 設(shè)計原理詞法分析的任務(wù):從左至右逐個字符地對源程序進行掃描,產(chǎn)生一個個單詞符號。理論基礎(chǔ):有限自動機、正規(guī)文法、正規(guī)式詞法分析器(LexicalAnalyzer)又稱掃描器(Scanner):執(zhí)行詞法分析的程序2. 詞法分析器的功能和輸出形式功能:輸入源程序、輸出單詞符號程序語言的單詞符號一般分為以下五種:關(guān)鍵字、標(biāo)識符、常數(shù)、運算
2、符界符3. 輸出的單詞符號的表示形式:單詞種別用整數(shù)編碼,關(guān)鍵字一字一種,標(biāo)識符統(tǒng)歸為一種,常數(shù)一種,各種符號各一種。4. 詞法分析器的結(jié)構(gòu)感謝下載載單詞符號5.狀態(tài)轉(zhuǎn)換圖實現(xiàn)字符/數(shù)字三、程序設(shè)計1.總體模塊設(shè)計/*用來存儲目標(biāo)文件名*/stringfile_name;/*提取文本文件中的信息。*/stringGetText();/*獲得一個單詞符號,從位置i開始查找。并且有一個引用參數(shù)j,用來返回這個單詞最后一個字符在str的位置。*/stringGetWord(stringstr,inti,int&j);/*這個函數(shù)用來除去字符串中連續(xù)的空格和換行intDeleteNull(st
3、ringstr,inti);/*判斷i當(dāng)前所指的字符是否為一個分界符,是的話返回真,反之假*/boolIsBoundary(stringstr,inti);/*判斷i當(dāng)前所指的字符是否為一個運算符,是的話返回真,反之假*/boolIsOperation(stringstr,inti);/*此函數(shù)將一個pair數(shù)組輸出到一個文件中*/voidOutFile(vector<pair<int,string>>v);/*此函數(shù)接受一個字符串?dāng)?shù)組,對它進行詞法分析,返回一個pair型數(shù)組*/vector<pair<int,string>>analyst(v
4、ector<string>vec);/*此函數(shù)判斷傳遞的參數(shù)是否為關(guān)鍵字,是的話,返回真,反之返回假*/boolIsKey(stringstr);2各模塊設(shè)計( 1).首先根據(jù)上面單詞符號表及ID和NUM的正規(guī)定義式,構(gòu)造出狀態(tài)轉(zhuǎn)換圖;( 2).定義相關(guān)的變量和數(shù)據(jù)結(jié)構(gòu)。關(guān)鍵字作為特殊標(biāo)識符處理,把它們預(yù)先安排在一張表格中(稱為關(guān)鍵字表),當(dāng)掃描程序識別出標(biāo)識符時,查關(guān)鍵字表。如能查到匹配的單詞,則該單詞為關(guān)鍵字,否則為一般標(biāo)識符。關(guān)鍵字表為一個字符串?dāng)?shù)組,其描述如下:charKEY_WORDS7="main","int"char"
5、,"if"else"for"while";用以存放單詞符號二元式的數(shù)據(jù)結(jié)構(gòu)可如下定義:classWord_Analyzerpublic:charContentMAXLENGTH;intval;voidprint();( 3).按照編譯程序一遍掃描的要求,把詞法分析器Scaner作為一個獨立的子程序來設(shè)計,通過對Scaner的反復(fù)調(diào)用識別出所有的單詞符號;( 4).當(dāng)Scaner識別出一個單詞符號時,則將該單詞符號的二元式寫入到輸出文件中。若Scaner無法識別出一個單詞符號時,則調(diào)用錯誤處理程序PrintError,顯示當(dāng)前掃描到的字符及其所在
6、行、列位置,并跳過該字符重新開始識別單詞符號。四、程序代碼#include<iostream>#include<vector>#include<string>#include<fstream>usingnamespacestd;/*用來存儲目標(biāo)文件名*/stringfile_name;/*提取文本文件中的信息。*/stringGetText();/*獲得一個單詞符號,從位置i開始查找。/并且有一個引用參數(shù)j,用來返回這個單詞最后一個字符在str的位置。*/stringGetWord(stringstr,inti,int&j);/*這個函數(shù)
7、用來除去字符串中連續(xù)的空格和換行/第一個參數(shù)為目標(biāo)字符串,第二個參數(shù)為開始位置/返回值為連續(xù)的空格和換行后的第一個有效字符在字符串的位置*/intDeleteNull(stringstr,inti);/*判斷i當(dāng)前所指的字符是否為一個分界符,是的話返回真,反之假*/boolIsBoundary(stringstr,inti);/*判斷i當(dāng)前所指的字符是否為一個運算符,是的話返回真,反之假*/boolIsOperation(stringstr,inti);/*此函數(shù)將一個pair數(shù)組輸出到一個文件中*/voidOutFile(vector<pair<int,string>>
8、;v);/*次函數(shù)將參數(shù)str,digit添加到temp中*/voidadd(stringstr,intdigit,vector<pair<int,string>>temp);/*此函數(shù)接受一個字符串?dāng)?shù)組,對它進行詞法分析,返回一個pair型數(shù)組*/vector<pair<int,string>>analyst(vector<string>vec);*/*此函數(shù)判斷傳遞的參數(shù)是否為關(guān)鍵字,是的話,返回真,反之返回假boolIsKey(stringstr);intmain()cout<<"*n"cout&
9、lt;<"*編譯原理課程設(shè)計-詞法編譯器ver1.0*n"cout<<"*n"cout<<endl;stringcom1=""stringcom2="n"stringfileline=GetText();intbegin=0,end=0;vector<string>array;dobegin=DeleteNull(fileline,begin);stringnowString;nowString=GetWord(fileline,begin,end);if(end=-1)b
10、reak;if(nowSpare(com1)&&nowSpare(com2)array.push_back(nowString);begin=end+1;while(true);vector<pair<int,string>>mid_result;mid_result=analyst(array);OutFile(mid_result);cout<<"*n"cout<<"*程序已完成詞法分析,分析結(jié)果已經(jīng)存儲在文件"<<file_name<<"中!*n&qu
11、ot;cout<<"*n"cout<<"感謝使用,謝謝再見!"<<endl;system("pause");return0;/*提取文本文件中的信息*/stringGetText()stringfile_name1;cout<<"請輸入源文件名(包括路徑和后綴名):"cin>>file_name1;ifstreaminfile(file_name1.c_str(),ios:in);if(!infile)cerr<<"無法打開文件!&q
12、uot;<<file_name1.c_str()<<"!"<<endl;exit(-1);cout<<endl;charf1000;infile.getline(f,1000,EOF);infile.close();printf(f);cout<<endl;returnf;/*獲得一個單詞符號,從位置i開始查找。/并且有一個引用參數(shù)j,用來返回這個單詞最后一個字符在原字符串的位置。*/stringGetWord(stringstr,inti,int&j)stringno_use("(),;n+=*
13、/-<>"");j=str.find_first_of(no_use,i);if(j=-1)return""if(i!=j)j-;returnstr.substr(i,j-i+1);/*這個函數(shù)用來除去字符串中連續(xù)的空格和換行/第一個參數(shù)為目標(biāo)字符串,第二個參數(shù)為開始位置/返回值為連續(xù)的空格和換行后的第一個有效字符在字符串的位置*/intDeleteNull(stringstr,inti)for(;i+)if(stri!=''&&stri!='n')returni;/*判斷i當(dāng)前所指的字符是否為
14、一個分界符,是的話返回真,反之假boolIsBoundary(stringstr,inti)intt;chararr7=',','','','','(',')',':'for(t=0;t<7;t+)if(stri=arrt)returntrue;returnfalse;/*判斷i當(dāng)前所指的字符是否為一個運算符,是的話返回真,反之假boolIsOperation(stringstr,inti)intt;chararr8='+','-','*
15、','/','=','<','>','&'for(t=0;t<8;t+)if(stri=arrt)returntrue;returnfalse;*/*/*此函數(shù)將一個個字符串?dāng)?shù)組輸出到一個文件中*/voidOutFile(vector<pair<int,string>>v)cout<<"請輸入目標(biāo)文件名(包括路徑和后綴名):”;cin>>file_name;ofstreamoufile(file_name.c_str(),i
16、os二out);if(!outfile)cerr<<"無法打開文件!"<<file_name.c_str()<<"!”<<endl;exit(-1);cout<<endl;inti;for(i=0;i<v.size();i+)outfile<<"<"<<vi.first<<",""<<vi.second<<"">"<<endl;cout&
17、lt;<"<"<<vi.first<<",""<<vi.second<<"">"<<endl;oufile<<"nn*n”;outfile.close();return;/*此函數(shù)判斷傳遞的參數(shù)是否為關(guān)鍵字,是的話,返回真,反之返回假*/boolIsKey(stringstr)stringp7="main","int","char","if&quo
18、t;,"else","for","while"vector<string>ppp(p,p+7);intu;for(u=0;u<ppp.size();u+)if(!pare(pppu)returntrue;returnfalse;/*此函數(shù)接受一個字符串?dāng)?shù)組,對它進行詞法分析,返回一個pair型數(shù)組*/vector<pair<int,string>>analyst(vector<string>vec)vector<pair<int,string>>temp;i
19、nti;for(i=0;i<vec.size();i+)if(veci.size()=1)精品if(veci=">"&&veci+1="=")stringjk=veci;jk.append(vec+i,0,1);pair<int,string>pp(37,jk);temp.push_back(pp);continue;if(veci="<"&&veci+1="=")stringjk=veci;jk.append(vec+i,0,1);pair<in
20、t,string>pp(38,jk);temp.push_back(pp);continue;if(veci="="&&veci+1="=")stringjk=veci;jk.append(vec+i,0,1);pair<int,string>pp(39,jk);temp.push_back(pp);continue;if(veci="!"&&veci+1="=")stringjk=veci;jk.append(vec+i,0,1);pair<int,stri
21、ng>pp(40,jk);temp.push_back(pp);continue;if(veci="&"&&veci+1="&")stringjk=veci;jk.append(vec+i,0,1);pair<int,string>pp(42,jk);temp.push_back(pp);continue;if(veci="|"&&veci+1="|")stringjk=veci;jk.append(vec+i,0,1);pair<int,st
22、ring>pp(43,jk);temp.push_back(pp);continue;if(IsBoundary(veci,0)if(veci=",")pair<int,string>pp1(32,veci);temp.push_back(pp1);if(veci="")pair<int,string>pp2(34,veci);temp.push_back(pp2);if(veci="")pair<int,string>pp3(30,veci);temp.push_back(pp3);if(v
23、eci="")感謝下載載精品pair<int,string>pp4(31,veci);temp.push_back(pp4);if(veci="(")pair<int,string>pp5(26,veci);temp.push_back(pp5);if(veci=")")pair<int,string>pp6(27,veci);temp.push_back(pp6);if(veci=":")pair<int,string>pp7(33,veci);temp.push_
24、back(pp7);elseif(IsOperation(veci,0)if(veci="+")pair<int,string>pp8(22,veci);temp.push_back(pp8);if(veci="-")pair<int,string>pp9(23,veci);temp.push_back(pp9);if(veci="*")pair<int,string>pp10(24,veci);temp.push_back(pp10);if(veci="/")pair<i
25、nt,string>pp11(25,veci);temp.push_back(pp11);if(veci="=")pair<int,string>pp12(21,veci);temp.push_back(pp12);if(veci=">")pair<int,string>pp13(35,veci);temp.push_back(pp13);if(veci="<")pair<int,string>pp14(36,veci);temp.push_back(pp14);if(veci=&
26、quot;&")pair<int,string>pp26(41,veci);temp.push_back(pp26);elseif(veci0<='9'&&veci0>='0')pair<int,string>pp24(10,veci);temp.push_back(pp24);elsepair<int,string>pp25(10,veci);temp.push_back(pp25);elseif(veci0<='9'&&veci0>='0')pair<int,string>pp23(3,veci);temp.push_back(pp23);elseif(IsKey(veci)if(veci="main")pair<int,string>pp15(1,veci);temp.push_back(pp15);if(veci="int")pair<int,string>pp16(2,veci);temp.push_back(pp16);if(veci="char
溫馨提示
- 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)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五年度建筑公司項目終止及工程變更審批合同3篇
- 2025年粵人版高三地理下冊階段測試試卷
- 2025年湘教新版八年級科學(xué)上冊階段測試試卷
- 2025年人教A新版選擇性必修2物理下冊月考試卷
- 2025年中圖版九年級生物下冊月考試卷含答案
- 二零二五年度能源采購合同節(jié)能減排與能源管理協(xié)議3篇
- 2025年華東師大版高三物理下冊階段測試試卷
- 2025年人教新起點四年級數(shù)學(xué)下冊階段測試試卷
- 2025年滬教版九年級歷史下冊階段測試試卷
- 2025年浙教版七年級地理上冊月考試卷
- 2024五凌電力限公司招聘5人高頻考題難、易錯點模擬試題(共500題)附帶答案詳解
- 循環(huán)系統(tǒng)練習(xí)試題(含答案)
- 2024年安徽醫(yī)學(xué)高等??茖W(xué)校高職單招(英語/數(shù)學(xué)/語文)筆試題庫含答案解析
- 昭通土豆市場調(diào)研報告
- 公司招標(biāo)管理辦法(國有企業(yè)適用) 94m
- 酒吧、夜店、KTV員工管理手冊(2022版)
- 國際法院規(guī)則全文
- 2023年初一美術(shù)工作總結(jié)
- 【GJB9001C內(nèi)審檢查表】2019年GJB9001C-2017質(zhì)量管理體系內(nèi)部審核檢查表(含完整檢查內(nèi)容)
- 醫(yī)院職能科室綜合質(zhì)量考核表
- 電信業(yè)務(wù)申請表
評論
0/150
提交評論