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

歲月流轉,往昔空明

C++博客 首頁 新隨筆 聯系 聚合 管理
  118 Posts :: 3 Stories :: 413 Comments :: 0 Trackbacks

4.從語法樹到OP CODE

知道咱們的虛擬機能夠執(zhí)行OP CODE之后,下一步就要考慮,怎么從語法樹里面生成咱們需要的OP CODE了。簡單來講,語法樹就是將程序的邏輯按照樹狀組織并保存在內存中的一種形式。有關于更詳細的信息,搜“Syntax Tree”,到處都是解釋。

一時不明白也沒關系,我們來看一個直觀的例子??紤]a+b這樣一個基本形式的表達式。這個表達式既可以按照我們所寫的這樣,分為a,+,b三個部分串行表示,也可以表示成下圖的樣子



可能一個表達式你還看不出來樹形的優(yōu)勢。要是表達式級聯起來,就顯示出這種表示的威力了:


 
這樣一個語法樹,可以不借助任何別的手段,保存了表達式的優(yōu)先級關系。這里的語法樹表示的就是(A+B)*C的表達式。同時,在語法樹上求值也很方便,后根遍歷語法樹就可以了。即先算出左右節(jié)點的值,再根據當前節(jié)點符號求出當前節(jié)點值。

王陽明說,知行合一。知道了語法樹是什么東西,我們就要開始考慮怎么用了。“怎么用”這個問題可以分成兩個部分,第一,語法樹怎么實現。第二,語法樹怎么生成op code。啊,先不要把語法樹想象的這么復雜。在這里,我們的運算符只有加號,一個加號也只能帶兩個int的值節(jié)點,而不能遞歸的帶上一個符號節(jié)點。也就是說,這棵樹只可能有一種形式而已。

首先來解決語法樹怎么實現的問題。在這個問題上,我們只需要把握一點,語法樹是一個天然的composite模式。我們用一個UML來看看這個只有加法算符的語法樹定義:
 
唔,很簡潔,不是么。Node_type是一個syntax_node_types類型的枚舉,這個枚舉告訴以后的代碼生成器這個抽象的node究竟是個什么類型,然后代碼生成器再還原它原本的類型并生成適當的代碼。op是一個operators類型的枚舉,表示一個二元運算的操作符。對于本例,只有operators::add可用。
在有了基本實現之后,再考慮一下其它需求,例如語法樹節(jié)點類型之間的可能存在的循環(huán)依賴問題,語法樹的深淺拷貝問題,等等,最終SASL的語法樹節(jié)點接口是這樣的:

 1 struct node{
 2     syntax_node_types type;
 3     template <typename NodeT> NodeT* clone() const;
 4     template <typename NodeT> NodeT* deepcopy() const;
 5 protected:
 6     virtual node* clone_impl() const = 0;
 7     virtual node* deepcopy_impl() const = 0;
 8 };
 9 
10 struct binary_expression: public node{
11     operators op;
12     boost::shared_ptr<constant> left_expr;
13     boost::shared_ptr<constant> right_expr;
14 };
15 
16 struct constant: public node{
17     int val;
18 };

道理復雜,不過實際上,并沒有那么復雜吧?
下面來解決第二個問題:怎么用表達式樹產生代碼?我不多解釋,直接上代碼,相信你一定會看明白的:

1 vm_codegen& vm_codegen::emit_expression( const binary_expression& expr ){
2     if ( expr.op != operators::add ){ return *this; }
3     int c0 = expr.left_expr->val;
4     int c1 = expr.right_expr->val;
5     ins_.push_back( instruction( op_loadrc, r0, c0 ) );
6     ins_.push_back( instruction( op_loadrc, r1, c1 ) );
7     ins_.push_back( instruction( op_add, r0, r1 ) );
8     return *this;
9 }


然后我們將生成語法樹,生成code,運行code的代碼補上,運行,OK~
你一定會說,啊,硬性綁定寄存器!太可怕了!如果表達式復雜了該怎么辦呢?呵呵。這些都是以后的問題了。以后的問題,就由以后的我們去解決好了。今日事,今日畢,時間不早,咱們還是洗洗睡了。

posted on 2009-12-11 10:04 空明流轉 閱讀(1963) 評論(3)  編輯 收藏 引用

評論

# re: 實用編譯器構建指南(二) 2009-12-11 11:09 正心
你為什么非要把代碼里帶上boost  回復  更多評論
  

# re: 實用編譯器構建指南(二) 2009-12-11 11:34 空明流轉
@正心
沒明白你什么意思。。。  回復  更多評論
  

# re: 實用編譯器構建指南(二) 2009-12-12 02:01 陳梓瀚(vczh)
@空明流轉
就是說為什么不using namespace boost;

話說,syntax_node_type type;是evil  回復  更多評論
  

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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下载红粉 | 一区二区三区你懂的| 久久永久免费| 欧美成人视屏| 久久人人97超碰人人澡爱香蕉 | 亚洲精品四区| 夜夜嗨av一区二区三区网页| 一区二区三区精品| 欧美亚洲在线| 美女国产一区| 亚洲欧洲午夜| 亚洲欧洲视频在线| 午夜精品福利一区二区三区av| 亚洲图色在线| 亚洲欧美视频一区| 欧美成人一区二区三区片免费 | 一区二区三区在线视频播放| 在线观看国产成人av片| 最新国产の精品合集bt伙计| 亚洲最快最全在线视频| 羞羞漫画18久久大片| 久久久国产亚洲精品| 亚洲国产cao| 亚洲女ⅴideoshd黑人| 久久综合99re88久久爱| 欧美日在线观看| 国产亚洲欧美在线| 99视频精品全部免费在线| 在线免费观看日本一区| 国产日本欧美在线观看| 亚洲欧洲日本在线| 欧美在线综合| 日韩午夜黄色| 久久久久国产一区二区三区四区| 免费成人毛片| 亚洲国产另类久久精品| 久久视频在线看| 国产精品观看| 好吊一区二区三区| 亚洲制服av| 亚洲二区在线视频| 亚洲一区欧美二区| 欧美日韩亚洲一区二区| 亚洲人成网在线播放| 久久国产精品毛片| 在线亚洲一区| 欧美精品一二三| 在线观看日韩av先锋影音电影院| 欧美一级视频精品观看| 亚洲欧洲日本国产| 久久久夜夜夜| 精品二区久久| 老司机一区二区| 欧美在线播放高清精品| 国产精品系列在线播放| 亚洲欧美不卡| 亚洲无亚洲人成网站77777| 欧美成人日本| 亚洲精品国产品国语在线app| 久久久久一区二区三区| 午夜亚洲福利在线老司机| 国产精品成人免费视频 | 欧美制服丝袜第一页| 一本色道久久综合亚洲精品高清 | 欧美激情一区二区三区在线视频观看 | 极品尤物久久久av免费看| 久久久久久久久久久成人| 亚洲欧美中文另类| 国产亚洲精品高潮| 久久综合色天天久久综合图片| 欧美在线精品免播放器视频| 国产一区在线看| 久久中文字幕导航| 免费毛片一区二区三区久久久| 亚洲精品1234| 日韩视频在线观看免费| 国产精品国产精品| 久久久久久久久久看片| 狂野欧美激情性xxxx| 亚洲精选久久| 亚洲一区欧美| 在线观看国产日韩| 亚洲人成人99网站| 国产女主播视频一区二区| 一区二区三区在线观看欧美| 免费久久99精品国产自在现线| 久久躁狠狠躁夜夜爽| 一本色道久久99精品综合 | 国产主播精品| 亚洲承认在线| 欧美视频在线观看 亚洲欧| 午夜精品视频一区| 久久综合导航| 亚洲欧美经典视频| 久久免费午夜影院| 国产精品99久久久久久久vr | 亚洲在线免费观看| 欧美在线三区| 亚洲网址在线| 久久先锋资源| 午夜精品久久久久久99热软件| 久久精品成人欧美大片古装| 亚洲欧洲视频| 欧美一区二区视频在线观看| 亚洲激情影视| 久久超碰97人人做人人爱| 亚洲最新在线视频| 久久久国产精品一区| 亚洲私人黄色宅男| 欧美成人精品激情在线观看 | 亚洲激情不卡| 国产综合欧美| 亚洲视频中文| 亚洲精品国产精品乱码不99按摩| 午夜精品999| 亚洲欧美日韩视频一区| 欧美成人一区二免费视频软件| 久久精视频免费在线久久完整在线看| 欧美国产日本在线| 久久综合给合久久狠狠色 | 亚洲精品一区二区三区樱花| 午夜免费久久久久| 亚洲综合精品四区| 欧美激情一区二区三区在线| 免费看亚洲片| 国产一区二区精品久久91| 一区二区三区欧美在线| 日韩一区二区免费高清| 美女视频黄a大片欧美| 久久久噜噜噜久久中文字幕色伊伊 | 99视频精品在线| 欧美成人国产| 欧美成人精品福利| …久久精品99久久香蕉国产| 欧美影院午夜播放| 久久久www| 精品成人在线观看| 久久视频国产精品免费视频在线 | 欧美激情第二页| 久久噜噜亚洲综合| 黄色欧美成人| 久热精品视频| 欧美激情精品久久久久| 亚洲国产裸拍裸体视频在线观看乱了| 欧美在线一二三区| 久久蜜桃精品| 亚洲大片一区二区三区| 欧美xx69| 亚洲最黄网站| 性8sex亚洲区入口| 国内外成人在线视频| 欧美一区久久| 欧美va天堂| 欧美成人精品在线播放| 亚洲国内高清视频| 欧美日韩第一区| 亚洲一区不卡| 欧美在线观看一区| 亚洲国产精品成人va在线观看| 欧美成人性网| 中文精品视频| 久久久久久久尹人综合网亚洲| 国内精品久久久| 老司机一区二区| 99国产一区| 久久久91精品国产| 日韩视频第一页| 国产精品久久久久久久久 | 欧美成人久久| 亚洲自拍电影| 免费国产自线拍一欧美视频| 一本色道久久88精品综合| 国产亚洲综合精品| 乱码第一页成人| 亚洲视频一二| 亚洲福利视频专区| 欧美一区综合| 99热这里只有精品8| 国产农村妇女精品一区二区| 免费成人激情视频| 午夜日韩在线| 日韩亚洲一区在线播放| 麻豆freexxxx性91精品| 亚洲综合99| 亚洲国产一区视频| 国产午夜精品久久久| 欧美日韩不卡一区| 久久久99久久精品女同性| 在线视频日韩精品| 亚洲国产精品女人久久久| 久久精品国产清高在天天线 | 欧美国产第一页| 久久精品在线播放| 亚洲欧美日韩综合国产aⅴ| 亚洲精品之草原avav久久| 久久在线免费观看| 欧美在线综合| 亚洲欧美激情一区二区| 一区二区三区国产| 99re8这里有精品热视频免费 |