程序語言的語法描述_第1頁
已閱讀1頁,還剩9頁未讀 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權,請進行舉報或認領

文檔簡介

1、第三講 程序語言的語法描述,作業(yè):P36(6,7,8) 其中6(2)做0127 8(1)做i+i*i,上下文無關文法語法范疇完全獨立于這種范疇可能出現(xiàn)的環(huán)境,1)文法與語言文法 上下文無關文法G是一個四元式(VT,VN,S,P)。其中 VT:非空集,每個元素叫終結符 VN:非空有限集,每個元素稱為非終結符 S: 非終結符,叫做開始符號 P: 產(chǎn)生式集(有限), 形式為 P-&

2、gt;?, 其中 P? VN, ??(VT ?VN)* 注意: 開始符S至少必須在某個產(chǎn)生式的左部出現(xiàn)一次. P-> ?1 P-> ?2 … P-> ?n 可以縮寫為 P-> ?1 | ?2 | …| ?n 每個?i 也叫 P 的一個侯選式. 討論中多以大寫字母表示非終結符,,語言 上下文無關文法定義語言的辦法: 從文法的開始符出發(fā),

3、反復連續(xù)使用產(chǎn)生式,對非終結符實施替換和展開.E.G. 文法 E->E+E |E*E | (E) | i (P28) 據(jù)規(guī)則: E ->(E),我們說: 從“E”可以直接推出“(E)”,記為 E=>(E); 對“(E)”中“E”再用 E->E+E 便有: (E)=>(E+E), 即由 “E” 可以推出(E+E). 表示為: E=>(E)=>(E+E),,基本術語(P29)

4、 學員閱讀直接推出推導可推導出?1 =+> ?n?1 =*> ?n 文法的句型 文法G的句子全體形成它的語言 L(G)= {?| S=*> ?且??VT*}最左推導(最右推導) E=>(E)=>(E+E) => (E*E+E) => (i*E+E) => (i*i+E) => (i*i+i),,2) 語法樹及二義性語法樹(P31圖

5、2.2,侯選式中自左至右的每個符號對應一個新結點) 包含了最左、最右推導,但不含所有可能推導 E ( E ) E + E文法的二義性

6、 E * E i i i,,,,,,,,,,,,,文法的二義性 文法二義性 若一文法中存在某個句子,它有兩個不同的最左 (最右)推導,或者說一文法存在某個句子對應兩 棵不同的語法樹. 例: P31圖2

7、.2, P32圖2.3 (i*i+i) 語言的二義性 某語言由不同文法刻畫 兩種二義性有何不同,,P28的表達式文法可以通過規(guī)定*,+優(yōu)先順序,結合規(guī)則而構造一無二義的文法. E -> T | E+T 概念分層思想 T -> F | T*F F -> (E) | i,,對上下文無關文法的兩點限制文法中不含任何 P->P 形式的產(chǎn)生式

8、 (會產(chǎn)生二義?)每個非終結符都有用處 即存在 S =*> ?? P ?, 則必有 ??VT*, 使得 P =*> ?.,,3) 形式語言鳥瞰 Chomsky 將文法分為四類: 0, 1, 2, 30: 每個產(chǎn)生式 ? ? ?滿足: ??(VN ?VT)*且至少含一個非終結符, 而 ? ?(VN ?VT)*.1: 每個產(chǎn)生式 ? ? ?滿足:

溫馨提示

  • 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. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論