下載本文檔
版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領
文檔簡介
1、 4/4編譯原理詞法分析和語法分析報告+代碼(C語言版) 詞法分析 一、實驗目的 設計、編制并調試一個詞法分析程序,加深對詞法分析原理的理解。 二、實驗要求 2.1 待分析的簡單的詞法 (1)關鍵字: begin if then while do end 所有的關鍵字都是小寫。 (2)運算符和界符 : = + - * / 9 then x:=2*x+1/3; end #的源文件,經過詞法分析后輸出如下序列: (1,begin)(10,x)(18,:=)(11,9)(26,;)(2,if) 三、詞法分析程序的算法思想: 算法的基本任務是從字符串表示的源程序中識別出具有獨立意義的單詞符號,其基本思
2、想是根據(jù)掃描到單詞符號的第一個字符的種類,拼出相應的單詞符號。 3.1 主程序示意圖: 主程序示意圖如圖3-1所示。其中初始包括以下兩個方面: 關鍵字表的初值。 關鍵字作為特殊標識符處理,把它們預先安排在一張表格中(稱為關鍵字表),當掃描程序識別出標識符時,查關鍵字表。如能查到匹配的單詞,則該單詞為關鍵字,否則為一般標識符。關鍵字表為一個字符串數(shù)組,其描述如下: Char *rwtab6 = “begin”, “if”, “then”, “while”, “do”, “end”,; 圖3-1 (2)程序中需要用到的主要變量為syn,token和sum 3.2 掃描子程序的算法思想: 首先設置3
3、個變量:token用來存放構成單詞符號的字符串;sum用來整型單詞;syn用來存放單詞符號的種別碼。掃描子程序主要部分流程如圖3-2所示。 圖 3-2 四、詞法分析程序的C語言程序源代碼: #include #include char prog80,token8,ch; int syn,p,m,n,sum; char *rwtab6=begin,if,then,while,do,end; scaner(); main() p=0; printf(n please input a string(end with #):/n); do scanf(%c, progp+=ch; while(ch!=
4、#); p=0; do scaner(); switch(syn) case 11:printf( %-10d%5d )n,sum,syn); break; case -1:printf(you have input a wrong stringn); getch(); exit(0); default: printf( %-10s%5d )n,token,syn); break; while(syn!=0); getch(); scaner() sum=0; for(m=0;m=0) ch=progp+; p-; syn=11; else switch(ch) case :tokenm+=c
5、h; ch=progp+; if(ch=) syn=24; tokenm+=ch; else syn=23; p-; break; case +: tokenm+=ch; ch=progp+; if(ch=+) syn=17; tokenm+=ch; else syn=13; p-; break; case -:tokenm+=ch; ch=progp+; if(ch=-) syn=29; tokenm+=ch; else syn=14; p-; break; case !:ch=progp+; if(ch=) syn=21; tokenm+=ch; else syn=31; p-; brea
6、k; case =:tokenm+=ch; ch=progp+; if(ch=) syn=25; tokenm+=ch; else syn=18; p-; break; case *: syn=15; tokenm+=ch; break; case /: syn=16; tokenm+=ch; break; case (: syn=27; tokenm+=ch; break; case ): syn=28; tokenm+=ch; break; case : syn=5; tokenm+=ch; break; case : syn=6; tokenm+=ch; break; case ;: syn=26; tokenm+=ch; break; case : syn=30; tokenm+=ch; break; case #: syn=0; tokenm+=ch; break; case :syn=17; tokenm+=ch; break; default: syn=-1; break; tokenm+=0; 五、結果分析: 輸入begin x:=9: if x9 then x:=2*x+1/3; end # 后經詞法分析輸出如下序列:(begin 1)(x 10)(:17)(= 18)(9 11)(;26)(if 2)如圖5-1所示
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
- 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 二零二五版美發(fā)培訓學校師資聘用標準合同4篇
- 2025年度門面租賃合同電子版(含租金遞增與調整機制)
- 2025年度簽競業(yè)協(xié)議打工人財產保全及職業(yè)規(guī)劃合同
- 二零二五年度酒店前臺員工權益保障與勞動合同
- 二零二五年度超市與物流公司貨物扣點運輸合同
- 2025年度復雜地質條件頂管施工安全協(xié)議書
- 2025年度住宅室內裝修工程保修協(xié)議
- 2025年度簽競業(yè)協(xié)議打工人財產保全及心理支持合同
- 2025年度跆拳道青少年運動員培養(yǎng)合作協(xié)議
- 二零二五年度退休人員教育輔助教學勞務合同
- 2024公共數(shù)據(jù)授權運營實施方案
- 2024年國家焊工職業(yè)技能理論考試題庫(含答案)
- 《向心力》 教學課件
- 結構力學數(shù)值方法:邊界元法(BEM):邊界元法的基本原理與步驟
- 2024年山東省泰安市高考語文一模試卷
- 北師大版物理九年級全一冊課件
- 2024年第三師圖木舒克市市場監(jiān)督管理局招錄2人《行政職業(yè)能力測驗》高頻考點、難點(含詳細答案)
- RFJ 006-2021 RFP型人防過濾吸收器制造與驗收規(guī)范(暫行)
- 盆腔炎教學查房課件
- 110kv各類型變壓器的計算單
- 新概念英語課件NCE3-lesson15(共34張)
評論
0/150
提交評論