日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

正则表达式引擎的构建——基于编译原理DFA(龙书第三章)——1 概述

發布時間:2023/12/10 编程问答 26 豆豆
生活随笔 收集整理的這篇文章主要介紹了 正则表达式引擎的构建——基于编译原理DFA(龙书第三章)——1 概述 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

說明:本系列文章介紹的算法均來自編譯原理(龍書)一書,如果讀者對代碼沒有興趣,只想了解算法思路,完全可以閱讀龍書相關章節內容,比我講得清晰透徹。


序:

? ? 啃編譯原理半年以來,任然徘徊在前4章,其間反反復復,時而不求甚解,時而略有所悟。其間接觸到正則表達式,對其實現原理頗有興趣,于是百度之、谷歌之,以求解惑。


先是搜索到不少國內發表的學術論文和各位大俠博客上的文章,后又通過文章鏈接中的鏈接找到一篇不錯的老外寫的文章,并附有源碼,看完了其文章,基本上和編譯原理(龍書)中介紹的先從正則表達式構造NFA,再將NFA轉化為DFA,最后在優化、化簡DFA的思路一樣。而我在下載其代碼后稍微看了一些片段,試運行了一下發現代碼寫的有BUG,內存釋放有問題,略覺不爽。于是便想自寫一個玩玩,但如若還按照從正則表達式到NFA,再從NFA到DFA的過程,又覺得重復別人的老路,參考別人的代碼頗無趣味。

老外的文章和代碼下載地址在這里:http://www.codeproject.com/Articles/5412/Writing-own-regular-expression-parser


于是翻看龍書第三章后半部分,看到有直接從正則表達式構造得到DFA的算法過程。覺得可以一試,于是就有了這篇系列文章,有了2個來星期的1000多行代碼(含空行^_^)。

根據正則表達式構造最小DFA的過程,總結如下:

1 根據正則表達式構造抽象語法樹T。

2 從T的根節點開始,進行深度優先遍歷,對每一個節點計算該節點的4個函數:nullable, firstpos, lastpos, followpos。

3 從T的根節點N0開始,構建狀態集列表LIST,開始時狀態集鏈表LIST中只包含firstpos(N0)。

4 遍歷LIST中的各個元素(開始的時候LIST中只有一個元素),假設當前遍歷到第i個元素,LIST(I)是一個集合,集合中每個節點對應的輸入字符是不一樣的,按照輸入字符對節點進行分組(例如代表字符a的分在一個組中,代表字符b的分在一個組中),對每個組中各個節點K計算followpos(K),followpos(K)也是一個集合,K可能不止一個,得到的結果可能是多個集合,將這多個集合合并為一個集合S。如果這個集合S在LIST中還沒有出現過,則將這個集合S加入到LIST中。同時,不管S是否在LIST中出現過沒有,都需要記錄下轉換過程:LIST(i)經過某個字符(前面分組過程依據的字符)到達集合S。就這樣一邊處理LIST鏈表,一邊記錄轉換過程,直到LIST中的元素依次從頭到尾都被處理完畢。

最后得到的LIST鏈表和所有轉換過程記錄就構成了一個有向圖,實質上就是一個DFA(確定性有窮狀態自動機)。

5 對得到的DFA進行最小化處理。

?

轉載于:https://www.cnblogs.com/snake-hand/archive/2013/06/09/3129886.html

總結

以上是生活随笔為你收集整理的正则表达式引擎的构建——基于编译原理DFA(龙书第三章)——1 概述的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。