• <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>

            woaidongmao

            文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數據加載中……

            用Flex/Bison分析c代碼的經歷

            這些日子花了不少時間在一個c語言的語法分析程序上,這個程序要能識別變量、函數的定義、聲明和引用,簡而言之就是找出sourceinsight所能提供的信息(比si還要精確)。

            分析代碼和編譯代碼一樣,都要做語法分析。但是因為分析代碼不做預處理,所以就會遇到一些麻煩,比如處理一些定義的稀奇古怪的宏,無法判斷一個identifier是變量還是類型。這么一來,嚴格的用C語言語法來分析代碼就沒法通過。

            考慮到這個問題,一開始決定用lex作詞法分析,生寫語法分析。進行到中間,代碼復雜度越來越高,感覺力不從心。又決定通過修改標準的C語言語法規則,用bisonyaccGNU實現)來完成語法分析

            所謂“工欲善其事,必先利其器”,bison在做語法分析上,果然很方便。但是很快就遇到上面所說的問題:不做預處理,無法得到一個token的類型。標準的yacc支持的是LALR語法,LALR語法只預讀一個token,無法解決這個問題。

            好在GNUYacc實現bison支持GLR語法GLR沒有只預讀一個token的限制,它用狀態分裂來解決無法判斷token類型的問題。采用GLR,寫語法規則就基本上沒有什么限制了。

            但是GLR有個問題,它用狀態分裂解決問題,如果所有分裂的狀態只有一個能分析成功,那自然OK;如果不能,就叫產生了ambiguity(不確定),分析就失敗了。

            解決ambiguity,可以用%dprec來指定規則的優先級。當兩個狀態發生ambiguity時,根據它們對應的reduce規則的優先級,選擇優先級高的那個狀態。

            但還有一類ambiguity的情況,用%dprec也沒發解決。那就是兩個產生ambiguity的狀態它們對應的reduce規則是同一條。這類問題很棘手,我只好采用重寫規則來避免。但這就導致規則的可讀性很差,而且往往是解決一個ambiguity又引入另外一個。

            無奈,往bisonmail list里發了一封信求救,第二天收到一哥們回信,信中說:

            “用merge啊。我也遇到過類似的問題。”

            merge是啥呢?merge就正好是處理上面這類問題的,相當于把多個狀態合并。因為是比較新的特性,在bison的文檔里并沒有很明顯的提及。

            這樣,用bison分析c代碼就基本沒有問題了;)

             

            備注

            Flex:詞法分析器

            Bison:語法分析器

            GNU bison是一個自由軟件,用于自動生成語法分析器程序,實際上可用于所有常見的操作系統。Bison把LALR形式的上下文無關文法描述轉換為可做語法分析的CC++程序。在新近版本中,Bison增加了對GLR語法分析算法的支持。

            GNU bison基本兼容Yacc,并做了一些改進。它一般與flex一起使用。

            posted on 2008-11-22 00:02 肥仔 閱讀(7851) 評論(1)  編輯 收藏 引用 所屬分類: LEX & YACC

            評論

            # re: 用Flex/Bison分析c代碼的經歷[未登錄]  回復  更多評論   

            果然想到一起了,最近也在做提取C變量、函數的定義之類的程序想用lex和yacc,也郁悶在預處理上了,不知項目能否開源參考一下?
            2012-11-19 15:45 | 逗你玩
            久久久久亚洲精品天堂久久久久久 | 久久久久久国产精品无码超碰| 久久综合亚洲鲁鲁五月天| 久久中文字幕人妻熟av女| 亚洲αv久久久噜噜噜噜噜| 精品综合久久久久久97超人 | 久久婷婷国产剧情内射白浆| 久久99久国产麻精品66| 伊人久久大香线蕉精品| 麻豆久久久9性大片| 婷婷综合久久狠狠色99h| 国产精品久久久久久久app| 97精品伊人久久大香线蕉app| 久久综合一区二区无码| 久久精品国产99国产精品澳门| 亚洲国产成人乱码精品女人久久久不卡| 亚洲国产精品无码久久久秋霞2 | 久久―日本道色综合久久| 久久婷婷色香五月综合激情| 成人国内精品久久久久一区| 久久人妻少妇嫩草AV蜜桃| 国内精品免费久久影院| 久久99精品国产麻豆宅宅| 亚洲第一极品精品无码久久| 思思久久99热只有频精品66| 久久av高潮av无码av喷吹| 久久精品国产99国产电影网 | 无码专区久久综合久中文字幕 | 亚洲精品无码久久一线| 一级女性全黄久久生活片免费 | 国产精品久久久久久久人人看 | 精品无码久久久久国产| 亚洲成色www久久网站夜月| 精品久久久久久国产| 久久人人爽人人人人爽AV | 亚洲精品午夜国产va久久| 人妻丰满?V无码久久不卡| 久久久久亚洲AV成人网| 久久精品无码一区二区三区免费 | 久久久久免费精品国产| 国产精品久久久久久|