青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆-341  評論-2670  文章-0  trackbacks-0

上一篇博客講到了構造符號表的事情。構造完符號表之后,就要進入語義分析的后一個階段了:構造狀態機。跟我以前寫的如何實現正則表達式引擎的兩篇文章講的一樣,自動機先從Epsilon Nondeterministic Automaton開始,然后一步一步構造成Deterministic Automaton。但是語法分析和正則表達式有很大不同,那么這個自動機是什么樣子的呢?

(對學術感興趣的人可以去wiki一下“下推自動機”)

下推自動機和有限自動機的區別是,下推自動機擴展成普通的自動機的時候,他的狀態的數目是無限的(廢話)。但是無限的東西是沒辦法用編程來表達的,那怎么辦呢?那就加入一個不定長度的“狀態描述”。下面我舉一個簡單的文法:

ID = NAME
IDList = ID | IDList “,” ID

這樣就構成了一個簡單的文法,用來分析帶逗號分割的名字列表的。那么寫成狀態機就是如下的形式:

ID0 = ● NAME
ID1 = NAME ●
IDList0 = ● (ID | IDList “," ID)
IDList1 = (ID | IDList “,” ID) ●
IDList2 = (ID | IDList ● “,” ID)
IDList3 = (ID | IDList “,” ● ID)

ID0 –> NAME –> ID1
IDList0 –> ID –> IDList1
IDList0 –> IDList –> IDList2
IDList2 –> “,” –> IDList3
IDList3 –> ID –> IDList1

可以很容易的看出,ID0和IDList0是文法的起始狀態,而ID1和IDList1是文法的終結狀態,畫成圖如下:

image

(PowerPoint畫圖復制到LiveWriter里面是一幅圖面簡直太方便了)

但是這樣還沒完。IDList0跳到IDList2的時候的輸入“IDList”其實還不夠,因為用作輸入的token其實只有NAME和","兩種。下一步即將演示如何從這個狀態機編程名副其實的下推狀態機。

在這里我先介紹幾個概念。第一個是移進,第二個是規約。為什么要用這兩個名字呢?因為大部分人看的傻逼清華大學出版社的低能編譯原理課本都是這么講的,黑化分別叫Shift和Reduce。好了,什么是Shift呢?IDList0跳到IDList2的時候,要移進IDList。IDList3跳到IDList1,要移進到ID。IDList0跳到IDList1也要移進到ID。這也就是說,狀態轉移經過一條非終結符的邊的時候會移進到另一條文法的狀態機里。ID1和IDList1作為ID和IDList的終結節點,要根據“從那里移進來的”分別規約然后跳轉到“IDList2或者IDList1”。這也就是說,一旦你到達了一條聞法的狀態機的終結狀態,就要開始規約然后跳轉到上一級的狀態了

有人要問,那我怎么知道規約結束的時候要跳轉去哪里呢?這個問題問得非常好。讓我們回想一下我以前寫的如何手寫語法分析器這一篇文章。里面怎么說的?當你手寫遞歸下降的語法分析器的時候,每一條文法其實都是一個函數。那調用函數的時候程序怎么就知道函數結束的時候下一條指令是什么呢?那當然是因為編譯器幫我們把“調用函數的時候的下一條指令的地址”給push進了調用堆棧。但是我們現在不手寫語法分析器了,而用下推狀態機來做,道理也是一樣的。在“移進”的時候,先把當前的狀態push進堆棧,規約的時候,就可以看一下“棧頂那幾個狀態都是什么”,配合一次向前查看(這就是Look Ahead。LALR的那個LA,LALR(1)就是在LA的時候偷看一個token),來決定規約到哪里去。至于LA在這里的深刻內涵我將下一篇文章再說。因為現在我還沒有做到Nondeterministic到Deterministic的一步,里面有很多黑科技,我想集中討論。

那現在讓我們把上面那幅圖的兩個狀態機連起來,產生一個下推自動機。但是在這里我先做第一步。因為IDList0到IDList1的跳轉是一個左遞歸的過程,先暫時不管。

image

橙色的邊都是一個輸入非終結符的跳轉,所以實際上在下推狀態機里面是不存在的。在這張圖里面我們處理了兩條ID的邊。IDList0會shift(就是在堆棧里面push)自己然后跳轉到ID0,因此ID1在查看到棧頂是IDList0的時候,他就知道走的是IDList0 –> ID –> IDList1這條路,因此就reduce并跳轉到了IDList1。IDList3同理。

但是Shift的時候并沒有產生輸入,所以實際上應該改成下面這個樣子。

image

這樣Shift邊也就有輸入了。而且ID0到ID1也廢掉了。實際上ID0自己也應該廢掉。現在還有一個問題沒解決,就是左遞歸和Reduce不產生輸入的問題。這兩個問題實際上是一起的。我們先來考慮一下為什么這里沒辦法用相同的辦法來把Reduce處理成產生輸入的。實際上是因為,你在這一個階段還不知道究竟Reduce要輸入什么才能跳轉,特別是token已經結束并且parse出了一個完整的IDList的時候。以前你們是不是在看《Parsing Techniques》和《龍書》都對為什么一個字符串結尾要產生一個$字符感到很困惑呢?實際上他是特別有用的。現在我們來給他加上大家就明白了。在這里,這個文法的目標是產生一個IDList結構,所以$當然也要加在IDList的終結狀態——IDList1上:

image

然后就輪到Reduce。ID1應該是Reduce到哪里了?第一步自然是Reduce到IDList1。那么IDList1又要Reduce到哪里呢?我們可以看到,在IDList結束的時候,要么就是跳到IDList2,要么就是跳到FINISH。但是IDList2是通過左遞歸產生的,我們先不管他。跳到FINISH需要什么條件呢?第一個是輸入$,第二個是Pop完狀態之后堆棧會為空。所以這個時候我們可以先修改一下ID1到IDList1的Reduce邊:

image

最后就是左遞歸了。左遞歸的處理有點像hack,因為實際上你不能預先判斷你要不要左遞歸(也就是看一下token stream有多少個逗號),然后先shift幾個IDList0進去,再慢慢來。所以我們只有在滿足跳轉關系的時候臨時插入一些IDList0。那么這個關系是什么呢?左遞歸的IDList結束——也就是從IDList0跳到IDList2——之后只有一種可能,就是輸入","。而且所有指向IDList1的邊都是輸入ID,所以這條左遞歸的線應該從ID1(ID的終結狀態)連到IDList2,并且在鏈接的時候補充“假shift IDList0”:

image

橙色的兩個狀態分別是整個parsing過程的起始狀態和終結狀態。這個時候我們把所有沒用的邊和狀態都干掉,就變成了:

image

是不是覺得特別親切呢,這不就是正則表達式NAME ( “,” NAME)*的狀態機嗎?這也是因為這個文法剛好可以表達為一個正則文法才有這樣的結果,如果我們給他加點兒括號改變點優先級什么的,那就會變成一個復雜得多的狀態機了。好了。現在我們來模擬一下下推狀態機的狀態轉換和堆棧操作過程,來分析一下A,B,C$這個輸入吧。

在下面的標示圖里面,我們用s|abc|def來分別表達當前狀態s、當前堆棧里的狀態abc(棧頂在右邊)和正在等待的輸入def。那么初始狀態肯定就是
IDList0 | null | A,B,C$

然后就開始了!(用文字表達實在是太難看了,所以貼成圖)

image

如果成功到達FINISH并且堆棧和輸入都全部沒有了的話,那就證明,parsing過程完美結束,沒有任何錯誤發生。

如何從文法生成下推自動機并完成parsing工作的大概過程就寫到這里了。目前開發進度是到“生成非確定性下推自動機”這里。當我完成了生成“確定性下推自動機”——也就是上面的最后一個狀態機圖的時候——就會開始寫下一篇文章,講面對復雜的文法的時候,下推自動機將要如何調整。同時將重點描述Look Ahead部分,以及為什么LALR(1)要設計成那個樣子。

posted on 2012-12-07 00:43 陳梓瀚(vczh) 閱讀(4626) 評論(2)  編輯 收藏 引用 所屬分類: C++

評論:
# re: 可配置語法分析器開發紀事(三)——生成下推自動機 2012-12-07 02:03 | DiryBoy
Orz  回復  更多評論
  
# re: 可配置語法分析器開發紀事(三)——生成下推自動機 2012-12-07 06:37 | lwch
很有激情......  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一区二区三区久久精品| 久久精品国产免费观看| 欧美大尺度在线观看| 蜜臀av在线播放一区二区三区| 亚洲国产裸拍裸体视频在线观看乱了| 免费一级欧美片在线观看| 免费成人美女女| 一区二区三区免费在线观看| 亚洲视频www| 亚洲国产99精品国自产| 亚洲黄色成人网| 欧美午夜片欧美片在线观看| 欧美亚洲一区三区| 久久综合国产精品台湾中文娱乐网| 亚洲黄色成人久久久| 夜夜爽www精品| 禁断一区二区三区在线| 亚洲精品久久久久久久久久久久久| 国产精品久久中文| 欧美成人嫩草网站| 国产精品久久久久77777| 久久综合伊人77777| 欧美日韩福利| 美女主播一区| 国产精品久久久久久久久久久久| 老司机精品久久| 国产精品福利在线观看网址| 欧美成人网在线| 国产日韩精品一区二区三区在线 | 亚洲午夜日本在线观看| 久久精品亚洲乱码伦伦中文 | 国产精品欧美日韩| 亚洲国产日韩一区二区| 国产日韩欧美一区二区三区在线观看 | 欧美人与禽性xxxxx杂性| 久久精品欧美日韩精品| 国产精品mv在线观看| 欧美激情a∨在线视频播放| 国产欧美欧美| 制服丝袜亚洲播放| 亚洲精品在线看| 久久精品国产免费| 欧美在线视频导航| 欧美国产一区视频在线观看| 久久久久9999亚洲精品| 午夜影院日韩| 欧美日在线观看| 亚洲国产小视频在线观看| 狠狠色综合色综合网络| 欧美一区成人| 香蕉国产精品偷在线观看不卡| 欧美国产视频日韩| 亚洲第一精品影视| 亚洲国产午夜| 男人插女人欧美| 欧美电影免费观看高清完整版| 国产午夜亚洲精品不卡| 午夜电影亚洲| 久久精品日韩一区二区三区| 国产视频精品xxxx| 久久不射中文字幕| 蜜桃av一区二区| 亚洲国产黄色| 欧美xx69| 亚洲剧情一区二区| 亚洲午夜未删减在线观看| 欧美日韩一卡| 亚洲素人在线| 久久gogo国模啪啪人体图| 国产日产欧产精品推荐色 | 亚洲国产精品成人| 免费91麻豆精品国产自产在线观看| 欧美成年人视频网站欧美| 亚洲电影免费观看高清完整版在线| 久久久久久综合| 亚洲激情视频在线播放| 亚洲一级电影| 国产精品自在欧美一区| 欧美一区视频| 欧美激情a∨在线视频播放| 99re6这里只有精品| 欧美午夜激情视频| 欧美在线观看你懂的| 免费欧美网站| 亚洲午夜精品久久久久久浪潮| 国产精品网站在线| 久久久噜噜噜| 亚洲精品一区二区三区在线观看 | 你懂的视频欧美| 一区二区三区色| 国产日韩在线亚洲字幕中文| 久久亚洲捆绑美女| 中文网丁香综合网| 久久久亚洲国产美女国产盗摄| 亚洲欧洲美洲综合色网| 国产精品欧美一区喷水| 久久久久久久高潮| 一区二区三区欧美成人| 老司机午夜精品| 亚洲视频视频在线| 亚洲国产精彩中文乱码av在线播放| 欧美日本韩国一区| 久久国产日韩欧美| 一本色道久久88综合日韩精品| 久久精品国产99| 亚洲蜜桃精久久久久久久| 欧美日韩精品伦理作品在线免费观看| 中日韩视频在线观看| 久热精品视频| 欧美一区二区三区四区高清| 亚洲国产一区二区三区在线播| 国产精品欧美日韩一区| 欧美激情第二页| 久久久免费精品视频| 亚洲午夜在线视频| 亚洲区一区二| 欧美高清视频一区二区| 久久精品久久99精品久久| 亚洲天堂免费观看| 亚洲精品综合久久中文字幕| 国产综合色产在线精品| 国产精品日韩在线观看| 欧美日韩在线高清| 欧美精品一区二区三| 噜噜噜在线观看免费视频日韩| 午夜免费日韩视频| 亚洲一区二区三区四区视频 | 一区二区免费在线视频| 亚洲国产精品欧美一二99| 黄色资源网久久资源365| 国产片一区二区| 国产精品亚洲第一区在线暖暖韩国| 欧美激情中文字幕乱码免费| 另类图片国产| 蜜桃久久精品一区二区| 美玉足脚交一区二区三区图片| 久久久久www| 久久国产精品电影| 久久av老司机精品网站导航| 欧美一区激情视频在线观看| 午夜亚洲激情| 久久激情久久| 久久久久久久综合狠狠综合| 久久精品国产精品| 久久久久免费观看| 欧美成人午夜激情视频| 欧美激情综合色综合啪啪| 欧美日韩国产高清视频| 欧美日韩一视频区二区| 国产精品电影网站| 国产女主播一区二区三区| 国产日产欧美精品| 亚洲电影激情视频网站| 亚洲乱码精品一二三四区日韩在线| 日韩西西人体444www| 亚洲一区bb| 久久久久久久波多野高潮日日| 久久久久中文| 亚洲福利视频专区| 一区二区免费在线视频| 亚洲欧美国内爽妇网| 久久久夜夜夜| 欧美日本簧片| 国产亚洲福利| 亚洲国产日韩欧美在线99| 亚洲少妇诱惑| 久久天天躁狠狠躁夜夜av| 亚洲国产午夜| 香蕉久久夜色精品国产使用方法| 久久www成人_看片免费不卡| 免费91麻豆精品国产自产在线观看| 欧美日韩在线大尺度| 激情欧美国产欧美| 亚洲图片欧洲图片av| 久久免费国产| 一区二区三区 在线观看视| 欧美中文字幕| 欧美视频在线一区| 悠悠资源网久久精品| 亚洲小说春色综合另类电影| 久久这里只精品最新地址| 亚洲免费成人av电影| 久久精品女人的天堂av| 国产精品theporn| 亚洲激情av在线| 亚洲视频1区2区| 久久www免费人成看片高清| 欧美日韩18| 伊人久久成人| 午夜视频在线观看一区| 亚洲黄色片网站| 久久大香伊蕉在人线观看热2| 欧美啪啪成人vr| 亚洲高清久久网| 久久久久国产精品一区三寸| 亚洲视频综合在线| 欧美精品一区二区精品网 | 欧美日韩国产一区二区三区| 精品动漫一区| 久久精品最新地址|