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

隨筆-341  評(píng)論-2670  文章-0  trackbacks-0
    可擴(kuò)展編譯器架構(gòu)的構(gòu)想是最近幾天在洗澡的時(shí)候才最終完成的。我在思考如何開(kāi)發(fā)一個(gè)可以同時(shí)給C、Pascal、Basic、Fortran和未知的類似語(yǔ)言使用的前端+后端。這只是VL++3.0的其中一個(gè)小部分,我把語(yǔ)言歸為幾類,C一類,C#一類,Javascript一類,還有其他的等等。這些類型會(huì)分別提供不同的前端支持。在設(shè)計(jì)第一類的編譯器期間遇到了點(diǎn)困難。

    第一個(gè)困難是語(yǔ)法樹(shù)很難統(tǒng)一。其實(shí)這并不是說(shuō)那些語(yǔ)言完全不同,而是在于我想讓這N種語(yǔ)言的區(qū)別只有從字符串到語(yǔ)法樹(shù)的部分,從語(yǔ)法樹(shù)開(kāi)始都執(zhí)行相同的代碼來(lái)編譯。這就遇到了點(diǎn)麻煩。在語(yǔ)法分析的過(guò)程中,對(duì)于Pascal我不知道Name(Param)究竟是函數(shù)調(diào)用還是強(qiáng)制類型轉(zhuǎn)換,對(duì)于Basic來(lái)說(shuō)我不知道Name(Param)是函數(shù)調(diào)用還是數(shù)組下標(biāo)。還有Pascal和Basic的and等操作符可以同時(shí)作用于整數(shù)和布爾型(C使用了&&和&,而且它們?cè)趯?shí)現(xiàn)上有巨大差別)。Pascal自己還擴(kuò)展了一些類型譬如說(shuō)set,Pascal和Basic還有字符串。所以在語(yǔ)法分析的時(shí)候很難構(gòu)直接造出FunctionInvokeExpression、SubscribeExpression和TypeCastExpression。

    第二個(gè)困難是擴(kuò)展的類型。上面提到了Pascal有自己的set,我如何讓我的編譯器從前端開(kāi)始就可以應(yīng)付一門(mén)類似的未知語(yǔ)言他自己的新東西。譬如說(shuō)未知的set類型,他也有自己的操作符(連已經(jīng)存在的操作符operator+也可以用的),代碼生成的時(shí)候還有自己的方法。這不僅要求語(yǔ)法樹(shù)是可擴(kuò)展的,接下來(lái)的一切包括符號(hào)表、語(yǔ)義分析、代碼生成等所有部分都需要可擴(kuò)展的。

    第三個(gè)困難是C自己造成的,他有一個(gè)十分討厭的地方。當(dāng)我得到ABC*DEF;的時(shí)候,語(yǔ)義分析沒(méi)開(kāi)始,我不可能知道這是乘法還是定義一個(gè)變量。

    思考了許久,得出一個(gè)大概的方案:我先定義一門(mén)比較嚴(yán)格的語(yǔ)言,然后讓C、Pascal、Basic和Fortran來(lái)定義自己與該語(yǔ)言的不同之處,從而盡可能復(fù)用編譯器其余相同的部分。想到這里我得到一個(gè)比較奇怪的做法:

    第一個(gè)做法是在語(yǔ)義分析的時(shí)候修改語(yǔ)法樹(shù)。對(duì)于C語(yǔ)言的ABC*DEF;,這是一個(gè)statement。我給出一個(gè)接口,這個(gè)接口在語(yǔ)義分析的過(guò)程中被調(diào)用。語(yǔ)義分析產(chǎn)生了大量的信息全部傳遞過(guò)去,然后再第一次接觸到一個(gè)statement的時(shí)候,調(diào)用其中的ReplaceStatement函數(shù)。這個(gè)時(shí)候接口的ReplaceStatement可以通過(guò)語(yǔ)義分析的結(jié)果看看需不需要修改這個(gè)節(jié)點(diǎn)。如果上下文是int a,b;,那么a*b;就會(huì)被替換為乘法表達(dá)式。如果上下文是typedef int a;,那么a*b;保持不變(因?yàn)槲夷J(rèn)是優(yōu)先看成變量聲明)。ReplaceStatement對(duì)于同一個(gè)statement只會(huì)調(diào)用一次。至于Pascal的集合操作也可以通過(guò)這個(gè)來(lái)完成。對(duì)于a+b,可以在ReplaceExpression里面查看a和b是不是集合類型,如果是的話替換成自己的PascalSetBinaryExpression。這個(gè)小技巧解決了語(yǔ)法分析的時(shí)候遇到的歧義問(wèn)題。這也是沒(méi)有辦法的辦法,因?yàn)檫@一次設(shè)計(jì)出來(lái)的結(jié)構(gòu)的目的是為了讓新的語(yǔ)言可以用很小的代價(jià)來(lái)實(shí)現(xiàn)。

    第二個(gè)做法是語(yǔ)法樹(shù)的所有部分譬如Type、Expression、Statement和Declaration都存在一個(gè)ExtendedType、ExtendedExpression、ExtendedStatement和ExtendedDeclaration,語(yǔ)言可以通過(guò)繼承這四個(gè)“擴(kuò)展類”來(lái)提供未知的東西,當(dāng)然這個(gè)時(shí)候就要連帶提供所有操作了,譬如說(shuō)根據(jù)語(yǔ)義分析的上下文來(lái)判斷他自己的ExtendedExpression的返回類型啦。

    至于符號(hào)表的可擴(kuò)展性,我設(shè)計(jì)了一個(gè)可以應(yīng)付絕大多數(shù)情況的通用符號(hào)表,因此隨時(shí)加入新的東西還是比較容易的。

    最新的代碼可以在http://vlpp.codeplex.com/這里獲得。
posted on 2010-01-31 00:13 陳梓瀚(vczh) 閱讀(2476) 評(píng)論(5)  編輯 收藏 引用 所屬分類: VL++3.0開(kāi)發(fā)紀(jì)事

評(píng)論:
# re: Vczh Library++3.0之可擴(kuò)展編譯器架構(gòu) 2010-01-31 07:29 | heixia108
gcc 就可以擴(kuò)展 :)   回復(fù)  更多評(píng)論
  
# re: Vczh Library++3.0之可擴(kuò)展編譯器架構(gòu) 2010-01-31 09:09 | 陳梓瀚(vczh)
@heixia108
擴(kuò)展gcc的方法是重寫(xiě)整個(gè)前端,顯然這不叫擴(kuò)展,應(yīng)該叫g(shù)cc提供了組件給你自己拼裝成新編譯器。  回復(fù)  更多評(píng)論
  
# re: Vczh Library++3.0之可擴(kuò)展編譯器架構(gòu) 2010-02-01 04:50 | SOS
我發(fā)現(xiàn)很多人都在洗澡時(shí)得到有用的信息。  回復(fù)  更多評(píng)論
  
# re: Vczh Library++3.0之可擴(kuò)展編譯器架構(gòu) 2010-02-01 21:22 | xxzh
@陳梓瀚(vczh)
Open Source 的LLVM,微軟的Phoenix,應(yīng)該和你想做編譯器擴(kuò)展差不多,或者更強(qiáng)大。  回復(fù)  更多評(píng)論
  
# re: Vczh Library++3.0之可擴(kuò)展編譯器架構(gòu) 2010-02-02 00:35 | 陳梓瀚(vczh)
@xxzh
目的還是不同的,我是想讓完全不同等級(jí)或范式的語(yǔ)言可以無(wú)縫協(xié)作。不過(guò)這個(gè)idea到底行不行還有待驗(yàn)證……  回復(fù)  更多評(píng)論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品国产77777蜜臀| 午夜国产欧美理论在线播放| 欧美.www| 欧美成人一区二区三区| 理论片一区二区在线| 久久久av水蜜桃| 蜜月aⅴ免费一区二区三区| 免费在线成人av| 欧美日韩国产首页| 国产精品久久久久久久久| 国产精品国产自产拍高清av王其| 欧美性猛交xxxx乱大交蜜桃| 国产精品欧美一区喷水| 国产日韩欧美日韩| 亚洲国产99| 一本色道精品久久一区二区三区| 亚洲视频一二| 久久久精品午夜少妇| 欧美成人影音| 一区二区成人精品| 午夜久久99| 久久久综合免费视频| 欧美大秀在线观看| 国产美女诱惑一区二区| 在线观看中文字幕不卡| 夜夜嗨av一区二区三区四区| 久久国产精品99国产精| 亚洲国产精品成人久久综合一区| 亚洲欧洲午夜| 亚洲视频一区二区在线观看| 久久精品国亚洲| 欧美日韩三级电影在线| 黄色工厂这里只有精品| 亚洲视频在线一区观看| 美女免费视频一区| 亚洲天堂黄色| 欧美激情中文字幕一区二区| 国产一区二区无遮挡| 亚洲一区免费观看| 免费日韩av| 久久成人免费电影| 欧美视频一区二区三区在线观看| 亚洲第一页中文字幕| 久久精品中文字幕一区二区三区| 99精品热6080yy久久| 欧美福利视频网站| 亚洲国产导航| 欧美h视频在线| 久久久久www| 性做久久久久久免费观看欧美 | 亚洲国产精品久久久久秋霞不卡 | 亚洲影视在线播放| 亚洲电影观看| 久久综合九色欧美综合狠狠| 国产日韩av在线播放| 亚洲专区欧美专区| 亚洲精品一区二区三区99| 女女同性精品视频| 亚洲高清视频中文字幕| 老鸭窝毛片一区二区三区| 欧美亚洲在线| 国产亚洲精品久久久久久| 午夜在线电影亚洲一区| 亚洲欧美国产精品专区久久| 国产精品欧美经典| 欧美亚洲日本一区| 欧美在线你懂的| 国产视频在线观看一区二区三区 | 亚洲精品字幕| 欧美激情精品久久久久久黑人| 91久久中文| 亚洲精品在线二区| 欧美体内she精视频| 亚洲欧美福利一区二区| 亚洲欧美国产精品专区久久| 精品成人一区二区三区四区| 欧美成人精品在线观看| 免费视频一区| 亚洲视频一区在线| 欧美一区国产一区| 亚洲成人在线网| 欧美激情精品久久久久久大尺度| 欧美国产精品一区| 亚洲欧美日韩综合aⅴ视频| 欧美自拍偷拍| 亚洲精品九九| 亚洲私人影院在线观看| 国产午夜一区二区三区| 欧美ab在线视频| 欧美日本高清一区| 亚洲专区一二三| 久久一区二区三区av| 一区二区精品国产| 久久精品国产91精品亚洲| 亚洲精品欧美精品| 亚洲免费在线看| 亚洲人成网站影音先锋播放| 亚洲另类视频| 狠狠入ady亚洲精品经典电影| 欧美黄色影院| 国产日韩欧美三区| 亚洲青色在线| 国产日本欧美在线观看| 亚洲高清视频一区| 亚洲第一精品电影| 亚洲第一精品影视| 国产精品男人爽免费视频1| 久久躁狠狠躁夜夜爽| 欧美视频网址| 亚洲高清资源综合久久精品| 国产精品一区在线播放| 91久久综合| 亚洲国产免费看| 久久av免费一区| 午夜视频在线观看一区| 欧美日韩国产综合视频在线观看中文 | 亚洲伦理中文字幕| 久久精品91久久久久久再现| 亚洲伊人色欲综合网| 欧美99在线视频观看| 久久精品一本| 国产精品影音先锋| 日韩视频在线一区| 一区二区久久| 欧美激情影院| 亚洲精品1区2区| 亚洲精品日本| 欧美成人中文| 亚洲国产一区在线| 亚洲七七久久综合桃花剧情介绍| 久久精品在线观看| 久久精品亚洲一区二区| 国产日韩精品一区二区浪潮av| 亚洲视频免费在线| 午夜久久tv| 国产欧美一区二区三区沐欲| 亚洲午夜久久久久久尤物| 亚洲欧美日韩一区在线| 欧美午夜宅男影院在线观看| aⅴ色国产欧美| 亚洲影院污污.| 国产精品视频yy9299一区| 亚洲在线观看免费| 欧美在线视频观看| 国内精品国产成人| 久久久国产一区二区| 欧美va天堂在线| 亚洲美女黄网| 国产精品高潮呻吟久久av无限 | 亚洲第一区在线| 欧美大片在线观看| 一本色道**综合亚洲精品蜜桃冫 | 一区二区国产在线观看| 亚洲一区二区三区乱码aⅴ蜜桃女 亚洲一区二区三区乱码aⅴ | 91久久久一线二线三线品牌| 欧美激情1区2区3区| 日韩视频在线一区二区| 午夜精品久久久久| 在线看成人片| 999在线观看精品免费不卡网站| 亚洲午夜精品久久久久久浪潮| 中文在线一区| 国产精品一区二区三区观看| 欧美一区国产在线| 欧美第一黄色网| 亚洲亚洲精品在线观看| 国产亚洲毛片| 欧美激情日韩| 欧美一区二区日韩| 亚洲国产精品女人久久久| 亚洲欧美日韩国产综合| 亚洲国产成人av在线| 欧美午夜宅男影院| 噜噜噜久久亚洲精品国产品小说| 亚洲伦理在线免费看| 久久亚洲高清| 亚洲一区国产精品| 亚洲人成在线影院| 国产欧美一区二区色老头| 免费在线亚洲| 久久国产婷婷国产香蕉| 一本色道久久加勒比88综合| 免费欧美日韩| 久久精品一区二区三区不卡| av成人毛片| 亚洲成人影音| 国产日韩欧美综合| 欧美三级特黄| 女女同性精品视频| 久久精品人人做人人综合| 亚洲性夜色噜噜噜7777| 亚洲国产一区二区三区高清 | 西西人体一区二区| 亚洲美女免费精品视频在线观看| 国产欧美日韩精品专区| 欧美日韩在线播放三区| 欧美大片免费| 欧美激情第六页| 欧美成人综合在线| 欧美jjzz|