版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領
文檔簡介
1、<p> 太 原 學 院</p><p><b> 課程設計報告書</b></p><p> 課程名稱 編譯原理 </p><p> 設計題目 構造LR(0)分析法語法分析器 </p><p> 專業(yè)班級 計
2、算機科學與技術13-4班 </p><p> 學 號 20130905405 </p><p> 姓 名 王芳芳 </p><p> 指導教師 吳海麗 </p>&
3、lt;p> 2016年 12 月 15日</p><p><b> 目 錄</b></p><p><b> 一、課題概述1</b></p><p><b> 二、系統(tǒng)分析2</b></p><p> 2.1 本課程設計的知識點2</p>&
4、lt;p> 2.1.1 詞法編譯器功能2</p><p> 2.1.2 詞法分析器的設計2</p><p> 2.1.3 動態(tài)模擬算法的基本功能2</p><p> 2.1.4 LR分析器的構成2</p><p> 2. 2解決問題的基本思路3</p><p> 2.3 需解決的關鍵技術3
5、</p><p> 2.4 功能模塊框圖3</p><p><b> 三、系統(tǒng)設計4</b></p><p> 3.1 算法描述4</p><p> 3. 2 實現(xiàn)方法6</p><p> 3.2.1 構造分析表6</p><p> 3.2.2程序設計
6、關鍵6</p><p> 3.2.3 LR(0)項目集規(guī)范族的構造6</p><p> 3.3 詳細流程圖7</p><p><b> 四、代碼編寫8</b></p><p> 4. 1 生成分析表代碼8</p><p> 4. 2分析句子代碼10</p>&l
7、t;p><b> 五、調(diào)試分析14</b></p><p> 六、運行與調(diào)試15</p><p><b> 總 結(jié) 17</b></p><p><b> 參考文獻18</b></p><p><b> 課題概述</b></
8、p><p> 《編譯原理》是計算機專業(yè)的一門重要的專業(yè)課程,其中包含大量軟件設計思想。通過課程設計,實現(xiàn)一些重要的算法,或設計一個完整的編譯程序模型,能夠進一步加深理解和掌握所學知識,對提高自己的軟件設計水平具有十分重要的意義。語法分析是編譯過程的第二階段,是編譯器前端的核心組成部分,在編譯系統(tǒng)中起到了至關重要的作用。自底向上的語法分析與自頂向下的語法分析相比,對將要分析的源程序有著更大的分析空間,從而受到了廣泛的
9、運用。</p><p> 本次課程設計的目標即是利用所學過的編譯原理的知識,利用LR(0)分析法,用C語言寫出一個簡單的LR(0)語法分析器。該語法分析器所要完成的功能是,對錄入的文法判斷它是否為LR(0)文法,如果是輸出LR (0)分析表;在給定文法的情況下,能夠利用LR(0)分析表,對用戶輸入的一串字符串用LR(0)分析法進行分析,判斷該字符串是否為符合給定文法的一個句子,建立文法及其LR分析表表
10、示的數(shù)據(jù)結(jié)構,設計并實現(xiàn)一個LR(0)的分析器。編譯器設計的編譯程序涉及到編譯五個階段中的三個,即詞法分析器、語法分析器和中間代碼生成器。編譯程序的輸出結(jié)果包括詞法分析后的二元式序列、變量名表、狀態(tài)棧分析過程顯示及四元式序列程序。整個編譯程序分為三部分:詞法分析部分、語法分析處理及四元式生成部分、輸出顯示部分。一個程序設計語言就是一個記號系統(tǒng),如同自然語言一樣,它的完整的定義應包括語法和語義兩個方面。所謂一個語言的語法是指一組規(guī)則,用它
11、可以形成和產(chǎn)生一個合適的程序。目前廣泛使用的手段是上下文無關文法,即用上下文無關文法作為程序設計語言語法的描述工具。LR分析法正是給出一種能根據(jù)當前分析棧中的符號串(通常以狀態(tài)表示)</p><p><b> 二、系統(tǒng)分析</b></p><p> 2.1 本課程設計涉及的知識點</p><p> 2.1.1 詞法編譯器功能</p&
12、gt;<p> (1)導入任意文法,也可以自己輸入。</p><p> (2)輸出文法的分析過程,以及判斷是否為LR (0)文法,輸出分析表。</p><p> ?。?)輸入句子,進行語法分析。</p><p><b> ?。?)輸出結(jié)構樹。</b></p><p> 2.1.2 詞法分析器
13、的設計</p><p> (1)寫出該語言的詞法規(guī)則。</p><p> (2)把詞法規(guī)則轉(zhuǎn)換為相應的狀態(tài)轉(zhuǎn)換圖。</p><p> (3)把各轉(zhuǎn)換圖的初態(tài)連在一起,構成識別該語言的自動機。</p><p> (4)設計掃描器;把掃描器作為語法分析的一個過程,當語法分析需要一個單詞時,就調(diào)用掃描器。掃描器從初態(tài)出發(fā),當識別一個單詞后便
14、進入終態(tài),送出二元式。</p><p> 2.1.3 動態(tài)模擬算法的基本功能</p><p> (1)輸入LR分析表和一個句子。</p><p> ?。?)輸出LR總控程序。</p><p> ?。?)輸出依據(jù)句子構對應的語法樹的過程。</p><p> (4)設計一個給定LR分析表,輸入一個句子,能由依據(jù)LR分
15、析表輸出與句子對應的語法樹,能對語法樹生成過程進行模擬。</p><p> ?。?)輸入句子:bccd#。</p><p> (6)根據(jù)文法產(chǎn)生的LR分析表。</p><p><b> ?。?)輸出結(jié)果</b></p><p> 2.1.4 LR分析器的構成</p><p> 一個LR分析器
16、由3個部分組成</p><p> ?。?)總控程序,也可以稱為驅(qū)動程序。對所有的LR分析器,總控程序都是相同的。</p><p> ?。?)分析表或分析函數(shù)。不同的文法分析表將不同,同一個文法采用的LR</p><p> 分析器不同時,分析表也不同,分析表又可以分為動作(ACTION)表和狀態(tài)(GOTO)表兩個部分,它們都可用二維數(shù)組表示。</p>
17、<p> ?。?)分析棧,包括文法符號和相應的狀態(tài)棧。它們均是先進后出棧。分析器的動作由棧頂狀態(tài)和當前輸入符號所決定(LR(0)分析器不需向前查看輸入符號)。</p><p> 2.2解決問題的基本思路</p><p> 1、用構造一個狀態(tài)轉(zhuǎn)換函數(shù)實現(xiàn)狀態(tài)轉(zhuǎn)換。</p><p> 2、再通過函數(shù)構造一個移進-歸約函數(shù)實現(xiàn)移進規(guī)約動作。</p&g
18、t;<p> 3、采用構造一個打印LR分析器的工作過程函數(shù)實現(xiàn)輸出。</p><p> 在規(guī)范規(guī)約的過程中,一方面記住已移進和規(guī)約出的整個符號串,另一方面根據(jù)所用的產(chǎn)生式推測可能碰到的輸入符號。每一項ACTION(s,a)所規(guī)定的動作不外是下述四種可能之一:(1)移進(2)規(guī)約(3)接受(4)報錯。</p><p> 2.3 需解決的關鍵技術</p>&l
19、t;p><b> ?。?)詞法編譯器。</b></p><p> ?。?)交互式面向?qū)ο蟮脑~法編譯器基本功能是。</p><p> ?。?)根據(jù)規(guī)約規(guī)則對字符進行歸約。</p><p> ?。?)符合條件時采取移進動作。</p><p> 2.4 功能模塊框圖</p><p><b&
20、gt; 圖1 功能模塊框圖</b></p><p><b> 三、系統(tǒng)設計</b></p><p><b> 3.1 算法描述</b></p><p><b> 1、已知文法G</b></p><p><b> (1) E→E+T</b&g
21、t;</p><p><b> (2) E→T</b></p><p><b> (3) T→T*F</b></p><p><b> (4) T→F</b></p><p><b> (5) F→(E)</b></p><p&
22、gt;<b> (6) F→i</b></p><p> 2、LR(0)分析表的構造算法如下:</p><p> 假設已構造出LR(0)項目集規(guī)范族為:C={I0,I1, … , In},其中Ik為項目集的名字,k為狀態(tài)名,令包含S′→·S項目的集合Ik的下標k為分析器的初始狀態(tài)。那么分析表的ACTION表和GOTO表構造步驟為:</p>
23、<p> (1) 若項目A→α·aβ屬于Ik且轉(zhuǎn)換函數(shù)GO(Ik,a)= Ij,當a為終結(jié)符時則置ACTION[k,a]為Sj,其動作含意為將終結(jié)符a移進符號棧,狀態(tài)j進入狀態(tài)棧,(相當狀態(tài)k時遇a轉(zhuǎn)向狀態(tài)j)。</p><p> (2) 若項目A→α· 屬于Ik,則對任何終結(jié)符a 和'#'號置ACTION[k,a]和ACTION[k,#]為"rj&q
24、uot;,j為在文法G′中某產(chǎn)生式A→α的序號。rj動作的含義是把當前文法符號棧頂?shù)姆柎翚w約為A,并狀態(tài)棧指針從棧頂向下移動|α|的長度 , 文法符號棧從棧頂彈出|α|個符號,非終結(jié)符A變?yōu)楫斍懊媾R的符號。</p><p> (3) 若GO(Ik,A)=Ij,則置GOTO[k,A]為"j",其中A為非終結(jié)符,表示當前狀態(tài)為"k"時,遇文法符號A時狀態(tài)應轉(zhuǎn)向j,因此A移
25、入文法符號棧,j移入狀態(tài)棧。</p><p> (4) 若項目S′→S·屬于Ik,則置ACTION[k,#]為"acc",表示接受。</p><p> (5) 凡不能用上述方法填入的分析表的元素,均應填上"報錯標志"。為了表的清晰我們僅用空白表示錯誤標志。</p><p> 根據(jù)這種方法構造的LR(0)分析表不
26、含多重定義時,稱這樣的分析表為LR(0)分析表,能用LR(0)分析表的分析器稱為LR(0)分析器,能構造LR(0)分析表的文法稱為LR(0)文法。</p><p> 產(chǎn)生如下所示的LR分析表 </p><p> 表 1 LR分析表</p><p> 這張分析表包括兩個部分,一是“動作”(ACTION)表,另一是
27、“狀態(tài)轉(zhuǎn)換”(GOTO)表。ACTION(S,a)規(guī)定了當狀態(tài)S面臨輸入符號a時應采取什么動作。GOTO(S,X)規(guī)定了狀態(tài)S面對文法符號X(終結(jié)符或非終結(jié)符)時下一狀態(tài)是什么。顯然,GOTO(S,X)定義了一個以文法符號為字母表的DFA。其中,S0為分析器的初態(tài);#為句子的左括號;a1a2……an為輸入串;其后的#為結(jié)束符(句子右括號)。分析過程每步的結(jié)果可表示為:(S0S1……Sm,#X1X2……Xm ai, ai+1……an#)。
28、</p><p><b> 3.2 實現(xiàn)方法</b></p><p> 3.2.1 構造分析表</p><p> LR分析器實質(zhì)上是一個帶先進后出存儲器(棧)的確定有限狀態(tài)自動機。LR分析器的每一步工作是由棧頂狀態(tài)和現(xiàn)行輸入符號所唯一決定的。構造一個int型二維數(shù)組table[13][9],用于存放LR分析表。并初始化。作者這樣規(guī)定:&l
29、t;/p><p> 0~11 表示 狀態(tài)Sj,其中0對應S0,1對應S1……</p><p> 21~26 表示 規(guī)約Rj,其中21對應R1,22對應R2……</p><p> 12 表示 “接受”。</p><p> -1 表示 規(guī)約出錯,報錯。</p><p> 3.2.2程
30、序設計關鍵</p><p> ?。?)在輸入串(句子)輸入的過程中,涉及到一個壓棧的問題。但是輸入串壓入的字符順序剛好與原理中的字符串模型剛好相反,這樣需要先彈出的反而在棧底。為了既要保證字符串輸入,又要讓輸入的字符串存儲順序與輸入的字符串相反。采取以下措施:</p><p> 先將輸入的字符串壓入符號棧symbol中,然后符號棧彈出的字符再壓入輸入串棧instr中,這樣實現(xiàn)了輸入串的倒
31、序存儲。</p><p> (2)狀態(tài)棧和符號棧輸出(遍歷)過程均采取自棧底到棧頂?shù)捻樞?,而輸入串棧則是采取自棧頂?shù)綏5椎捻樞蜉敵觥?lt;/p><p> 3.2.3 LR(0)項目集規(guī)范族的構造</p><p> 識別活前輟的NFA我們可以利用子集法將其確定化。對確定化后的DFA如果把每個子集中所含狀態(tài)集對應的項目寫在新的狀態(tài)中。對于構成識別一個文法活前綴的DF
32、A項目集(狀態(tài))的全體稱為這個文法的LR(0)項目集規(guī)范族,我們可以分析每個狀態(tài)中項目集的構成,不難發(fā)現(xiàn)如下規(guī)律:</p><p> 若狀態(tài)中包含形如A→α·Bβ的項目,則形如B→·γ的項目也在此狀態(tài)內(nèi)。例如:0狀態(tài)中項目集為{S′→·E,E→·aA, E→·bB}。</p><p> 回顧由NFA確定化到DFA時,E→·aA
33、和E→·bB正是屬于S′→·E的閉包中。因而,可引入閉包函數(shù)(CLOSURE)來求DFA一個狀態(tài)的項目集。</p><p> 若文法G已拓廣為G′,而S為文法G的開始符號,拓廣后增加產(chǎn)生式S′→S。如果I是文法G′的一個項目集,定義和構造I的閉包CLOSURE(I)如下:</p><p> (1) I的項目均在CLOSURE(I)中。</p><
34、p> (2) 若A→α·Bβ屬于CLOSURE(I),則每一形如B→·γ的項目也屬于</p><p> CLOSURE(I)。</p><p> (3) 重復(2)直到不出現(xiàn)新的項目為止。即CLOSURE(I)不再擴大。</p><p> 由此,我們可以很容易構造出初態(tài)的閉包,即S′→·S屬于I,再按上述三點求其閉包。&l
35、t;/p><p><b> 3.3 詳細流程圖</b></p><p> 圖3.1 LR分析器設計流程圖</p><p> 圖2 LR分析器設計流程圖</p><p><b> 四、代碼編寫</b></p><p> 4.1 生成分析表代碼</p>&l
36、t;p> void CLR0ForWinDlg::OnGtable() </p><p><b> {</b></p><p> CTableDlg dlg;</p><p> dlg.SetControlInfo(IDC_EXPLORER1, RESIZE_BOTH);</p><p> dlg.Set
37、ControlInfo(IDOK, ANCHORE_BOTTOM | ANCHORE_RIGHT);</p><p> dlg.SetControlInfo(IDC_EXPORT, ANCHORE_BOTTOM | ANCHORE_RIGHT);</p><p> dlg.SetControlInfo(IDC_ANALYZE, ANCHORE_BOTTOM | ANCHORE_RIGH
38、T);</p><p> string temp = "";</p><p> CString t;</p><p> for(int i = 0; i < m_vtlist.GetCount(); i++)</p><p><b> {</b></p><p>
39、 m_vtlist.GetText(i,t);</p><p> //temp.push_back(t.GetAt(0));</p><p> temp += t.GetAt(0);</p><p><b> }</b></p><p> dlg.g.SetVt(temp);</p><p&
40、gt; temp = "";</p><p> for(i = 0; i < m_vnlist.GetCount(); i++)</p><p><b> {</b></p><p> m_vnlist.GetText(i,t);</p><p> //temp.push_back(t
41、.GetAt(0));</p><p> temp += t.GetAt(0);</p><p><b> }</b></p><p> dlg.g.SetVn(temp);</p><p> m_startedit.GetWindowText(t);</p><p> if (t ==
42、 "")</p><p><b> {</b></p><p> MessageBox("輸入的文法有誤,請檢查!", "錯誤",MB_OK | MB_ICONSTOP);</p><p><b> return;</b></p><p&
43、gt;<b> }</b></p><p> dlg.g.SetStart(t.GetAt(0));</p><p> temp = "";</p><p> for(i = 0; i < m_plist.GetCount(); i++)</p><p><b> {<
44、/b></p><p> temp = "";</p><p> m_plist.GetText(i,t);</p><p> for(int j = 0; j < t.GetLength(); j ++)</p><p> //temp.push_back(t.GetAt(j));</p>
45、<p> temp += t.GetAt(j);</p><p> dlg.g.AddPrecept(temp);</p><p><b> }</b></p><p> if(dlg.g.IsGrammarLegal())</p><p><b> {</b></p&
46、gt;<p> dlg.g.GenerateLR0Table();</p><p> dlg.DoModal();</p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p>
47、<p> MessageBox("輸入的文法有誤,請檢查!", "錯誤",MB_OK | MB_ICONSTOP);</p><p><b> }</b></p><p><b> }</b></p><p><b> 4.2分析句子代碼</
48、b></p><p> void CAnalyzeDlg::OnButton1() </p><p><b> {</b></p><p> // TODO: Add your control notification handler code here</p><p> UpdateData(TRUE);
49、</p><p> m_pTree->m_tree.DeleteAllItems();</p><p> for(int i = 0; i < m_input.GetLength(); i ++)</p><p><b> {</b></p><p> if (!m_g.IsInVt(m_input.
50、GetAt(i)))</p><p><b> {</b></p><p> MessageBox("輸入的句子不全部由終結(jié)符組成", "錯誤", MB_OK | MB_ICONSTOP);</p><p><b> return;</b></p><p&g
51、t;<b> }</b></p><p><b> }</b></p><p> assert(TreeStack.empty());</p><p> m_input += "#";</p><p> char szTempPath[MAX_PATH]; </p
52、><p> char szTempName[MAX_PATH]; </p><p> if (m_strTempFilename != "")</p><p> ::DeleteFile(m_strTempFilename.c_str());</p><p> ::GetTempPath(100,szTempPath)
53、;</p><p> ::GetTempFileName(szTempPath,"LR0",0,szTempName);</p><p> m_strTempFilename = szTempName;</p><p> CStdioFile out;</p><p> out.Open(szTempName, C
54、File::modeCreate | CFile::modeWrite);</p><p> out.WriteString("<html>\n");</p><p> out.WriteString("<head>\n");</p><p> out.WriteString("<
55、title>Untitled Document</title>\n");</p><p> out.WriteString("<meta http-equiv=\"Content-Type\" content=\"text/html; charset=gb2312\">\n");</p><p
56、> out.WriteString("</head>\n");</p><p> out.WriteString("<body bgcolor=\"#FFFFFF\" text=\"#000000\">\n");</p><p> out.WriteString("
57、<table border=\"1\" cellpadding=\"0\" cellspacing=\"0\" style=\"border-collapse: collapse\" bordercolor=\"#111111\">\n");</p><p> out.WriteStrin
58、g("<tr>\n<td nowrap> 步驟 </td>\n<td nowrap> 狀態(tài)棧</td>\n<td nowrap> 符號棧 </td>\n<td nowrap> 輸入串 </td>\
59、n<td nowrap> ACTION </td>\n<td nowrap > GOTO </td>\n </tr>\n");</p><p> vector <int> Status;</p><p> vector <cha
60、r> Symbol;</p><p> int iStep = 1;</p><p> int iPos = 0;</p><p> Status.push_back(0);</p><p> Symbol.push_back('#');</p><p> Pair ToDo;</
61、p><p> bool bErrorFlag = false;</p><p> bool bGoOn = true;</p><p> while ((bGoOn) && (!bErrorFlag))</p><p><b> {</b></p><p> assert(i
62、Pos < m_input.GetLength());</p><p> assert(Status.size() == Symbol.size());</p><p> ToDo = m_g.GetAction(Status.back(), m_input.GetAt(iPos));</p><p><b> int i, j;</b&
63、gt;</p><p> switch (ToDo.one)</p><p><b> {</b></p><p><b> case 'S':</b></p><p> out.WriteString(GetStepInfo(iStep, Status, Symbol, m
64、_input.Right(m_input.GetLength() - iPos), ToDo, -1));</p><p> Symbol.push_back(m_input.GetAt(iPos));</p><p> Status.push_back(ToDo.two);</p><p><b> iPos++;</b></p&
65、gt;<p><b> break;</b></p><p><b> case 'R':</b></p><p> j = m_g.GetGoTo(Status[Status.size()-m_g.GetPrecept(ToDo.two).GetRight().length()-1], m_g.GetPrec
66、ept(ToDo.two).GetLeft()[0]);</p><p> assert(j != -1);</p><p> out.WriteString(GetStepInfo(iStep, Status, Symbol, m_input.Right(m_input.GetLength() - iPos), ToDo, j));</p><p> for
67、(i = 0; i < m_g.GetPrecept(ToDo.two).GetRight().length(); i++)</p><p><b> {</b></p><p> Status.pop_back();</p><p> Symbol.pop_back();</p><p><b>
68、 }</b></p><p> Symbol.push_back(m_g.GetPrecept(ToDo.two).GetLeft()[0]);</p><p> Status.push_back(j);</p><p> TreeStack.push(ToDo.two);</p><p><b> break
69、;</b></p><p><b> case 'a':</b></p><p> if (m_input.GetAt(iPos) == '#')</p><p><b> {</b></p><p> out.WriteString(GetSte
70、pInfo(iStep, Status, Symbol, m_input.Right(m_input.GetLength() - iPos), ToDo, -1));</p><p> bGoOn = false;</p><p><b> }</b></p><p><b> else</b></p>
71、<p> bErrorFlag = true;</p><p><b> break;</b></p><p><b> case 0:</b></p><p> bErrorFlag = true;</p><p><b> break;</b><
72、/p><p><b> default:</b></p><p> assert(false);</p><p><b> }</b></p><p><b> iStep++;</b></p><p><b> }</b>&
73、lt;/p><p> out.WriteString("</table>");</p><p> if (bErrorFlag)</p><p><b> {</b></p><p> out.WriteString("<p><font color=\&qu
74、ot;#FF3300\">分析失敗,輸入的字符串是不符合預定文法的!</font></p>\n");</p><p> //m_pTree->m_tree.DeleteAllItems();</p><p> while(!TreeStack.empty())</p><p> TreeStack.pop
75、();</p><p><b> }</b></p><p><b> else</b></p><p><b> {</b></p><p> out.WriteString("<p><font color=\"#009900\&
76、quot;>分析完成,輸入的字符串是預定文法的句子</font></p>\n");</p><p> //HTREEITEM h = m_pTree->m_tree.GetRootItem();</p><p> //ExpandTree(h);</p><p> MakeTree();</p>&l
77、t;p><b> }</b></p><p> out.WriteString("</body>\n</html>");</p><p> out.Close();</p><p> m_web.Navigate(szTempName,NULL,NULL,NULL,NULL);</
78、p><p> m_edit1.SetFocus();</p><p> m_edit1.SetSel(0, -1);</p><p><b> }</b></p><p><b> 五、調(diào)試分析</b></p><p> 編完自己的程序,然后在將其他組員的程序整合起來后
79、就進行了,首先將所有的程序進行測試和編譯檢查有沒有錯誤,有錯誤的話先修改正確,在調(diào)試的過程中,先輸入字符串,進行規(guī)約,要注意的是一定要輸入可以規(guī)約的字符串且要在字符串的最后輸入一個“#”號作為規(guī)約的結(jié)束標志,如果沒有加上“#”結(jié)束符號,導致系統(tǒng)認為用戶的輸入串并沒有結(jié)束,不斷的進行規(guī)約,并且在規(guī)約的時候要特別注意各棧的值的情況,因為最后要輸出結(jié)果,如果輸入的是不可規(guī)約的字符串那系統(tǒng)就會出錯不能完成規(guī)約。</p><p
80、><b> 六、運行與調(diào)試</b></p><p><b> 圖3 導入文法界面</b></p><p> 圖4 生成分析表界面</p><p><b> 圖5 分析句子界面</b></p><p> 圖6 生成語法樹界面</p><p&g
81、t;<b> 總 結(jié)</b></p><p> 編譯原理是一門很重要的課程。我們平常寫小的C語言程序會感到困難,而編譯原理則是關于編寫編譯器的技術,難度之大可想而知。編譯器的編寫一直被認為是十分困難的事情,難怪第一Fortran的編譯器據(jù)說花了18年的時間才完成。當然編譯原理和編譯技術并不是相同的,編譯原理更注重理論方面的知識,編譯技術更注重實際編寫編譯器過程中用到的技術。在編程序的過
82、程中,有時會和一個小小的錯誤較上半天的勁,等到最后才發(fā)現(xiàn)只是由于語法用的不正確,算法是可行的。這樣在一個小小的語法錯誤上浪費許多時間是很不值得,所以在今后的語言學習中,我會重視語法的細節(jié)。另外在程序設計上,以前自己傾向于直接寫程序,很少使用流程圖。后來發(fā)現(xiàn)先設計出流程圖,那么程序的結(jié)構就會清晰的多,編寫的時候也會更節(jié)省時間。在整個程序中,我認為其中逆波蘭式的構造和自動機的構造都是比較難的,是通過對基礎知識的詳細深入回顧得出,特別是自動機
83、的確定化過程煩鎖又耗時,采用了鄰接表進行存儲。上機的調(diào)試時間也不是很長,但程序的最大問題就是可讀性不強,雖基本功能能達到理想的效果。</p><p><b> 參考文獻</b></p><p> 1、陳意云.編譯原理和技術.中國科技大學出版社,1997</p><p> 2、金成植.編譯程序構造原理和實現(xiàn)技術.高等教育出版社,2006&l
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
- 4. 未經(jīng)權益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責。
- 6. 下載文件中如有侵權或不適當內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 編譯原理課程設計-詞法語法分析器
- 編譯原理課程設計--- 語法分析器
- 編譯原理課程設計---語法分析器
- 編譯原理課程設計--語法分析器
- 編譯原理語法分析器課程設計
- 編譯原理詞法分析器語法分析課程設計
- 編譯原理課程設計(c++)-語法分析器
- 語法分析課程設計---編譯原理語法分析器的設計與實現(xiàn)
- 編譯原理課程設計--表達式語法分析器
- 編譯原理課程設計--pascal語言詞法、語法分析器設計
- lr(0)分析表及分析器的構造課程設計
- 編譯原理課程設計-lr分析器總控程序的實現(xiàn)
- 課程設計----編譯原理詞法分析器
- c-minus詞法分析和語法分析設計編譯器編譯原理課程設計
- 編譯課程設計-遞歸下降語法分析
- 編譯原理課程設計--c-編譯器詞法分析與語法分析的實現(xiàn)
- 編譯原理課程設計詞法分析器文檔
- 編譯原理語法分析
- 編譯原理課程設計報告詞法分析器
- 編譯原理課程設計報告之詞法分析器
評論
0/150
提交評論