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

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 肥仔 閱讀(7878) 評論(1)  編輯 收藏 引用 所屬分類: LEX & YACC

評論

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

果然想到一起了,最近也在做提取C變量、函數的定義之類的程序想用lex和yacc,也郁悶在預處理上了,不知項目能否開源參考一下?
2012-11-19 15:45 | 逗你玩
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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香蕉一区二区| 亚洲第一黄网| 亚洲专区在线视频| 亚洲午夜激情免费视频| 久久精品理论片| 午夜影视日本亚洲欧洲精品| 久久久另类综合| 久久久精品日韩欧美| 欧美日韩视频不卡| 欧美成人午夜视频| 国产一区二区三区在线观看免费视频 | 毛片基地黄久久久久久天堂| 欧美日韩国产一区二区三区| 欧美福利精品| 亚洲国产影院| 卡通动漫国产精品| 欧美福利一区二区三区| 亚洲高清不卡av| 免费一级欧美片在线观看| 久久久久久自在自线| 国产日产精品一区二区三区四区的观看方式| 亚洲成人中文| 亚洲欧洲一区二区三区在线观看 | 亚洲精品视频免费观看| 一本色道久久99精品综合| 欧美精品九九| av成人激情| 久久黄色影院| 亚洲每日在线| 精品999日本| 欧美黑人国产人伦爽爽爽| 亚洲福利国产| 先锋影音国产精品| 在线观看日韩av| 欧美日韩国产综合久久| 亚洲永久在线| 91久久久一线二线三线品牌| 亚洲精品一线二线三线无人区| 久久色中文字幕| 一区二区三区国产盗摄| 久久久久免费| 99这里只有精品| 国产午夜久久久久| 欧美日韩国产免费| 久久riav二区三区| 亚洲精品乱码| 欧美国产视频日韩| 欧美一区国产一区| 99视频+国产日韩欧美| 国产主播精品在线| 国产精品久久中文| 欧美aa在线视频| 欧美劲爆第一页| 亚洲午夜小视频| 久久精品麻豆| 一本久道久久综合狠狠爱| 欧美手机在线| 中文精品视频一区二区在线观看| 欧美一级免费视频| 国产视频久久久久| 欧美极品影院| 欧美片网站免费| 亚洲欧美日韩一区| 在线亚洲精品| 亚洲视频图片小说| 在线精品国产成人综合| 欧美视频中文字幕| 欧美日韩免费观看一区三区 | 一区二区高清视频| 亚洲人成网站精品片在线观看 | 亚洲视频在线观看三级| 99精品视频网| 在线一区二区三区四区| 亚洲精品中文在线| 亚洲精品视频一区| 亚洲精品中文字幕在线观看| 亚洲国产欧美不卡在线观看| 免费h精品视频在线播放| 免费国产自线拍一欧美视频| 久久综合色婷婷| 欧美大片国产精品| 亚洲人成网在线播放| 一本色道久久综合亚洲精品小说| 在线午夜精品自拍| 久久av一区二区三区漫画| 久久超碰97中文字幕| 免费在线成人av| 欧美日韩成人综合天天影院| 欧美日一区二区在线观看 | 欧美成人黄色小视频| 欧美激情一区二区三区在线| 欧美日韩妖精视频| 国产亚洲欧美aaaa| 91久久久国产精品| 亚洲欧美一区二区视频| 免费在线观看成人av| 亚洲午夜免费视频| 久久久99精品免费观看不卡| 欧美日韩国产影院| 亚洲高清不卡| 久久9热精品视频| 亚洲三级网站| 久久久国产精品一区二区中文| 欧美另类变人与禽xxxxx| 国产日韩欧美视频| 一区二区三区日韩精品视频| 久久久久在线| 亚洲免费在线| 国产精品vvv| 99国产精品国产精品久久| 久久久久久久久综合| 一区二区三区产品免费精品久久75 | 亚洲国产美女精品久久久久∴| 欧美亚洲免费| 国产精品久久久久久户外露出| 一区二区三区在线免费观看 | 亚洲午夜伦理| 亚洲国产另类久久久精品极度| 欧美一级视频精品观看| 欧美精品日韩三级| 欲色影视综合吧| 久久一区二区三区av| 新狼窝色av性久久久久久| 国产精品久久久久久久久久免费看 | 欧美在线亚洲综合一区| 国产精品一国产精品k频道56| 亚洲欧美视频在线| 亚洲天堂av图片| 欧美性事在线| 性做久久久久久久免费看| 亚洲视频免费在线| 国产精品午夜av在线| 久久亚洲一区| 国产精品一区二区久久国产| 久久国产精品久久久| 午夜视频久久久| 国产视频欧美视频| 久久亚洲综合色一区二区三区| 久久天堂成人| 一本到12不卡视频在线dvd| 在线视频亚洲欧美| 国产私拍一区| 欧美激情麻豆| 国产精品久久久爽爽爽麻豆色哟哟| 亚洲欧美日韩精品久久久| 欧美一区二区三区四区在线观看地址| 国产欧美一区二区三区沐欲 | 欧美国产日韩一区二区| 欧美日韩ab片| 免费观看久久久4p| 国产精品高清一区二区三区| 久久久久一区二区三区四区| 欧美精品一级| 老司机免费视频久久 | 亚洲精品免费观看| 亚洲神马久久| 日韩视频在线观看免费| 亚洲综合成人在线| 野花国产精品入口| 欧美在线免费一级片| 亚洲一区在线视频| 久久欧美中文字幕| 欧美在线中文字幕| 欧美韩日视频| 玖玖玖国产精品| 亚洲一二三四区| 久久久在线视频| 久久久99爱| 国产精品视频一二| 在线亚洲国产精品网站| 亚洲欧洲一区| 欧美激情综合在线| 你懂的视频一区二区| 在线观看三级视频欧美| 久久精品av麻豆的观看方式| 久久精品国产综合精品| 欧美日韩免费观看一区| 亚洲一区二区三区精品动漫| 欧美成人午夜激情| 欧美国产精品久久| 亚洲国产欧美在线人成| 欧美一区二区三区免费观看视频 | 亚洲在线观看视频| 欧美一区二区三区另类| 国产精品丝袜白浆摸在线| 香蕉亚洲视频| 久久综合九色九九| 狠狠色2019综合网| 久久久久久有精品国产| 麻豆免费精品视频| 在线国产欧美| 欧美激情久久久久久| 一区二区三区精密机械公司 | 亚洲女人天堂成人av在线| 国产视频在线观看一区二区| 欧美在线视频免费播放| 亚洲第一精品久久忘忧草社区| 日韩视频专区|