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

            loop_in_codes

            低調(diào)做技術(shù)__歡迎移步我的獨(dú)立博客 codemaro.com 微博 kevinlynx

            [總結(jié)]語法制導(dǎo)翻譯/語義分析

            語義分析理論中并沒有語法和詞法分析階段中那么多算法。如同整個(gè)編譯原理里大部分理論
            一樣,其都是為實(shí)踐編碼提供理論支持,從而可以讓實(shí)現(xiàn)簡單機(jī)械地進(jìn)行---語法制導(dǎo)翻譯
            也正是出于這個(gè)目的:通過建立理論,使得從語法樹翻譯到中間代碼(或者虛擬機(jī)代碼)更
            為簡單。

            個(gè)人理解,語法制導(dǎo)翻譯就是在文法中加上屬性和各種動(dòng)作,這些動(dòng)作基本也就是這里的“
            翻譯”;而語義分析,則是在整個(gè)過程所要進(jìn)行的一些上下文相關(guān)的分析動(dòng)作(如類型檢查
            )。

            羅列一些概念:

            - 屬性:就是語法樹各個(gè)節(jié)點(diǎn)上所需要的“值”,例如對于算術(shù)表達(dá)式a=b+c,在其語法樹
            中,每一個(gè)節(jié)點(diǎn)都會(huì)有一個(gè)數(shù)字屬性。屬性明顯不止包含數(shù)字/值這些東西,某個(gè)節(jié)點(diǎn)包含
            哪些具體屬性完全取決于編譯器實(shí)現(xiàn)的需要。對于表達(dá)式a=b如果需要檢查a和b的類型是否
            可以賦值(如在c語言中,struct XXX b就無法傳給int a),就需要在其節(jié)點(diǎn)中附加類型屬
            性。---這里舉的例子也正是一種語義分析行為。

            - 綜合屬性:某個(gè)節(jié)點(diǎn)的屬性依賴于其子節(jié)點(diǎn)的屬性,這種屬性計(jì)算起來很簡單,尤其在遞
            歸下降分析程序中。

            - 繼承屬性:某個(gè)節(jié)點(diǎn)的屬性依賴于其父節(jié)點(diǎn)或者其兄弟節(jié)點(diǎn)。這個(gè)屬性計(jì)算起來要稍微麻
            煩一些,需要一種屬性傳遞機(jī)制。在上一篇LL分析法的練習(xí)程序中,就使用了一個(gè)“值?!?br>來傳遞屬性。

            - 依賴圖:上面提到屬性之間的依賴,在一棵語法中,通過箭頭描繪出這種依賴關(guān)系就得到
            依賴圖,說白了就是拿來方便看的,無視。

            - 語法制導(dǎo)定義(SDD):學(xué)編譯原理最煩的就是這些定義,一句話里總覺得有若干未知概
            念,尤其在翻譯比較爛的時(shí)候。我覺得這個(gè)SDD就是在文法中穿插了若干屬性和翻譯動(dòng)作的
            表示。

            - S屬性的SDD:如果一個(gè)SDD的每一個(gè)屬性都是綜合屬性,那它就是S屬性的。

            - L屬性的SDD:無視了,就是夾雜著綜合屬性和繼承屬性的SDD,不過繼承屬性有諸多條件
            限制,大致上就是其某個(gè)屬性的依賴關(guān)系僅限于其左兄弟或者父節(jié)點(diǎn)。

            其實(shí)這一切都并非它看上去的那么繁雜。在有了語法分析的基礎(chǔ)上,因?yàn)轳R上涉及到翻譯為
            中間代碼(甚至?xí)苯臃g為虛擬機(jī)代碼),在這個(gè)階段直接把代碼中會(huì)做的事情書寫到文
            法里,就得到了SDD。按照這個(gè)SDD,就可以較為機(jī)械地對應(yīng)寫出代碼。另一方面,在實(shí)際中
            為了處理不同的翻譯問題,如類型檢查、各種控制語句的翻譯,直接參考相關(guān)的資料,看看
            別人怎么處理的就行了。

            練習(xí)程序是一個(gè)簡單地處理c語言定義變量、定義struct類型的代碼。因?yàn)閏語言里的變量會(huì)
            附帶類型屬性,用于類型檢查之類的問題,所以程序中保存這些變量的符號表自然也要保存
            其類型。定義新的struct類型我這里直接建立了一個(gè)類型表,用于存儲(chǔ)所有的類型:基本類
            型和程序員自定義類型。

            練習(xí)程序直接使用了lex和yacc來生成詞法和語法分析模塊,通過直接在文法文件里(*.y)的
            文法中穿插各種動(dòng)作來完成具體的處理邏輯。本來我最開始是想個(gè)類型檢查程序的,起碼可
            以檢查一般的類型不匹配錯(cuò)誤/警告,不過后來僅僅做了變量/類型定義,就發(fā)現(xiàn)有一定代碼
            量了,索性就懶得做下去了。

            下載例子

            posted on 2010-03-28 20:19 Kevin Lynx 閱讀(10183) 評論(3)  編輯 收藏 引用 所屬分類: 編譯原理

            評論

            # re: [總結(jié)]語法制導(dǎo)翻譯/語義分析 2010-03-28 20:57 空明流轉(zhuǎn)

            依賴圖可不僅僅是用于“看的”。Hi和Mid Level的代碼優(yōu)化很大程度上依賴于依賴圖。  回復(fù)  更多評論   

            # re: [總結(jié)]語法制導(dǎo)翻譯/語義分析 2010-03-29 01:51 陳梓瀚(vczh)

            實(shí)際上你很難在yacc的語義動(dòng)作里面完成所有事情,因?yàn)橐淮芜f歸是遠(yuǎn)遠(yuǎn)不夠的。其實(shí)在實(shí)際編寫編譯器的經(jīng)驗(yàn)看,語義知道分析只是一個(gè)美好的愿望,當(dāng)成shit,忽略掉就好了。  回復(fù)  更多評論   

            # re: [總結(jié)]語法制導(dǎo)翻譯/語義分析 2010-03-29 01:51 陳梓瀚(vczh)

            當(dāng)然,如果你用prolog來做的話,還有可能實(shí)現(xiàn)語義知道分析……  回復(fù)  更多評論   

            国内精品久久人妻互换| 亚洲日韩中文无码久久| 色婷婷久久综合中文久久蜜桃av| 久久亚洲中文字幕精品一区四| 精品久久一区二区三区| 久久人人妻人人爽人人爽| 久久精品日日躁夜夜躁欧美| 久久久久久久久久久| 国产精品久久久香蕉| 一本久久知道综合久久| 久久久无码精品亚洲日韩按摩| 久久66热人妻偷产精品9| AV色综合久久天堂AV色综合在| 99久久久精品| 九九久久精品国产| 一本久久综合亚洲鲁鲁五月天亚洲欧美一区二区 | 国产精品一区二区久久| 久久99热国产这有精品| 久久精品这里只有精99品| 欧美伊人久久大香线蕉综合69| 久久99热这里只频精品6| 久久99精品久久久久婷婷| 国产精品日韩欧美久久综合| 区亚洲欧美一级久久精品亚洲精品成人网久久久久 | 欧美黑人激情性久久| 欧美牲交A欧牲交aⅴ久久| 久久国产精品久久久| 久久亚洲天堂| 丰满少妇高潮惨叫久久久| 精品久久久久一区二区三区 | 久久婷婷五月综合色高清 | 久久亚洲av无码精品浪潮| 97精品依人久久久大香线蕉97| …久久精品99久久香蕉国产| 久久国产精品波多野结衣AV| 欧美牲交A欧牲交aⅴ久久| 久久99精品国产麻豆蜜芽| 国产成人精品久久二区二区| 中文字幕精品久久久久人妻| 成人资源影音先锋久久资源网| 午夜精品久久久久久影视riav |