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

隨筆-91  評論-137  文章-0  trackbacks-0
QLanguage開源項目地址:http://qlanguage.codeplex.com

1.AST的每個節點由2個域組成,這2個域分別表示當前節點的類型和附加信息。
2.AST的每個節點包含一個指向其子節點的順序表。
3.AST的每個節點包含指向下一個節點的指針。
綜上所述我們得到AST節點的代碼:
 1     class CSyntaxTreeNode
 2     {
 3     public:
 4         CSyntaxTreeNode(int _type,int _value) : type(_type),value(_value){}
 5 
 6         inline List<NAutoPtr<CSyntaxTreeNode>>& Child()
 7         {
 8             return child;
 9         }
10 
11         inline NAutoPtr<CSyntaxTreeNode> Next()
12         {
13             return next;
14         }
15 
16         inline int& Type()
17         {
18             return type;
19         }
20 
21         inline int& Value()
22         {
23             return value;
24         }
25     protected:
26         int type;
27         int value;
28         List<NAutoPtr<CSyntaxTreeNode>> child;
29         NAutoPtr<CSyntaxTreeNode> next;
30     };
然后我們給出了部分枚舉來標識節點的類型:
 1         // for type
 2         enum TYPE
 3         {
 4             stNull,
 5             stDeclare,
 6             stFunction,
 7             stParamterList,
 8             stIf,
 9             stDo,
10             stExp,
11         };
最后是一棵AST的整體結構:
 1 class CParserAnalyze
 2 {
 3 public:
 4     inline void Push(NAutoPtr<CSyntaxTreeNode>& Node)
 5     {
 6         SyntaxTreeStack.Push(Node);
 7     }
 8 
 9     inline NAutoPtr<CSyntaxTreeNode> Pop()
10     {
11         return SyntaxTreeStack.Pop();
12     }
13 
14     inline NAutoPtr<CSyntaxTreeNode> Top()
15     {
16         return SyntaxTreeStack.Top();
17     }
18 
19     inline NAutoPtr<CSyntaxTreeNode> Root()
20     {
21         return SyntaxTreeRoot;
22     }
23 protected:
24     NAutoPtr<CSyntaxTreeNode> SyntaxTreeRoot;            // 語法樹根節點
25     Stack<NAutoPtr<CSyntaxTreeNode>> SyntaxTreeStack;    // 語法樹棧
26 };

這里我們簡單的分析一下分析過程:
以if語句為例,其組合子代碼為:
1     if_desc = (str_if + exp_desc)[if_desc_first] +
2             (str_then + stmt_list)[if_desc_second] +
3             Parser_Combinator_Node::opt((str_else + stmt_list)[if_desc_third]) +
4             (str_end + str_if)[if_desc_fourth];
我們輸入代碼:
1     if a then
2         declare b as integer
3     end if
在做語法分析:
1.讀入if a,a被歸約為一條exp生成一個類型為exp的節點并壓入AST的語法樹棧。
2.if a被歸約生成一個類型為stIf的節點并彈出棧頂的exp節點填充到新生成的stIf節點的第一個子節點。
3.讀入then declare b as integer,integer被歸約生成一個生類型為stDeclare的節點并壓入語法樹棧。
4.declare b as integer被歸約為棧頂的stDeclare節點填充一個b標識符的子節點。
5.then declare b as integer被歸約,首先彈出棧頂的stmt_list因為這里是stDeclare說明stmt_list有內容應此將棧頂的stIf的值域的最低位置為1。
6.else子句不存在。
7.整體被歸約。
此時棧頂為stIf節點,其不包含next節點,有兩個子節點分別為stExp和stDeclare。

分析過程如下圖:
1.
2.
3.
4.
5.
6.
7.
posted on 2011-07-01 21:51 lwch 閱讀(2223) 評論(2)  編輯 收藏 引用 所屬分類: QLanguage

評論:
# re: QLanguage的AST 2011-07-02 10:06 | 千暮(zblc)
你畫的好屎 推薦你一款關聯畫圖軟件 XMind  回復  更多評論
  
# re: QLanguage的AST 2011-07-02 10:25 | lwch
@千暮(zblc)
Word畫出來的...  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美国产1区2区| 欧美激情久久久久久| 国产在线播精品第三| 在线视频日本亚洲性| 免费观看30秒视频久久| 亚洲尤物在线| 99精品国产在热久久| 欧美日韩一级大片网址| 欧美国产综合视频| 欧美成在线视频| 免费成人网www| 蜜桃av噜噜一区二区三区| 久久激情五月激情| 欧美电影电视剧在线观看| 亚洲一区二区精品在线观看| 日韩视频在线一区二区| 亚洲黄页视频免费观看| 亚洲国产影院| 日韩一级在线| 亚洲丰满少妇videoshd| 亚洲福利国产| 亚洲欧洲三级| 亚洲国产日韩精品| 亚洲精品一区中文| 一区二区三区久久网| 一区二区三区四区在线| 亚洲一区视频| 久久精品免费电影| 欧美成人tv| 亚洲欧洲在线视频| 99精品欧美一区二区三区综合在线| 日韩亚洲视频在线| 亚洲欧洲在线视频| 亚洲欧美国产日韩天堂区| 香蕉免费一区二区三区在线观看 | 欧美日韩亚洲三区| 国产精品va在线播放| 国产精品日本欧美一区二区三区| 免费在线视频一区| 欧美另类人妖| 国产午夜精品久久久久久久| 伊人成年综合电影网| 一区二区三区黄色| 久久野战av| 亚洲看片网站| 久久精品午夜| 欧美日韩一级片在线观看| 国产女人精品视频| 91久久线看在观草草青青| 亚洲视频在线观看| 宅男噜噜噜66国产日韩在线观看| 久久久人成影片一区二区三区观看| 欧美国产日韩在线观看| 亚洲国产日韩美| 亚洲图片在线观看| 久久午夜精品| 欧美调教视频| 国产精品欧美日韩| 国产精品久久久久久av下载红粉| 韩国一区二区三区在线观看| 欧美伊人久久久久久久久影院| 欧美激情一区二区| 欧美一级艳片视频免费观看| 欧美日韩国内| 国产欧亚日韩视频| 欧美在线999| 一本久道久久久| 久久久久久综合| 加勒比av一区二区| 欧美一区二区三区另类| 亚洲美女少妇无套啪啪呻吟| 久久天天狠狠| 国产精品成人午夜| 中文精品一区二区三区| 一区二区三区免费看| 欧美大片第1页| 亚洲欧洲日本国产| 欧美亚洲一区二区在线观看| 亚洲在线免费观看| 国产精品久久久久婷婷| 一区二区三区鲁丝不卡| 亚洲深夜福利视频| 国产精品v欧美精品v日韩精品| 亚洲精品美女在线观看| 久久久久久精| 麻豆成人综合网| 亚洲成人在线免费| 欧美大片国产精品| 久久国产色av| 亚洲日本成人| 亚洲国产小视频在线观看| 久久久精彩视频| 1000精品久久久久久久久| 亚洲精品专区| 国产精品二区二区三区| 亚洲一区二区精品| 亚洲婷婷在线| 亚洲高清不卡| 亚洲国产精品成人综合| 欧美精品免费播放| 亚洲伊人网站| 久久―日本道色综合久久| 在线日韩电影| 亚洲国产精品一区二区第四页av| 久久国产精品网站| 亚洲美女性视频| 亚洲免费不卡| 国产亚洲成人一区| 欧美大片在线观看| 久久高清国产| 欧美不卡高清| 亚洲欧美在线免费观看| 国产精品视频午夜| 免费视频一区二区三区在线观看| 欧美人与性禽动交情品| 欧美在线不卡| 欧美日韩直播| 欧美国产在线视频| 国产综合色产| 亚洲综合日韩在线| 亚洲视频碰碰| 欧美激情国产高清| 欧美电影在线观看完整版| 国产欧美精品日韩| 亚洲人成网站影音先锋播放| 国产主播精品在线| 亚洲一区二区少妇| 中文高清一区| 欧美精品色综合| 亚洲国产成人精品女人久久久| 韩日精品视频| 欧美一区观看| 久久精品亚洲精品国产欧美kt∨| 国产精品久久久久一区二区三区| 亚洲美女中文字幕| 中日韩美女免费视频网站在线观看| 欧美不卡一区| 亚洲日韩欧美视频一区| 99ri日韩精品视频| 欧美日韩1080p| 亚洲精品乱码久久久久久| 亚洲毛片在线看| 免费国产一区二区| 蜜臀av性久久久久蜜臀aⅴ| 精品成人在线视频| 久久久亚洲精品一区二区三区| 久久综合色88| 亚洲激情婷婷| 欧美刺激午夜性久久久久久久| 欧美不卡视频一区发布| 亚洲国内精品| 欧美午夜电影在线| 亚洲欧美日韩国产一区二区三区| 久久精品首页| 亚洲第一精品久久忘忧草社区| 久久夜色精品国产亚洲aⅴ| 欧美福利在线| 中国av一区| 国产欧美日韩视频在线观看| 久久精品国产久精国产一老狼| 免费试看一区| 亚洲美洲欧洲综合国产一区| 欧美午夜精品一区| 亚洲欧美日韩一区二区在线| 久久夜色精品国产| 亚洲免费电影在线| 国产精品香蕉在线观看| 久久久视频精品| 99精品99| 久热精品视频| 一区二区三区日韩在线观看| 国产欧美亚洲视频| 欧美成人xxx| 亚洲欧美成人在线| 亚洲大胆人体在线| 欧美一区二区在线视频| 亚洲欧洲日韩女同| 国产婷婷97碰碰久久人人蜜臀| 国产欧美精品一区| 欧美电影免费| 亚洲尤物视频在线| 亚洲性视频网站| 欧美日韩在线一区| 一本色道久久综合亚洲精品婷婷| 欧美一区二区三区在线视频| 亚洲一区二区三区在线看| 欧美日韩国产bt| 香蕉成人啪国产精品视频综合网| 亚洲欧洲日韩女同| 国产欧美亚洲精品| 亚洲视频碰碰| 亚洲欧美日韩电影| 91久久线看在观草草青青| 亚洲女爱视频在线| 亚洲精品乱码久久久久久| 国产一区二区三区无遮挡| 欧美三级网页| 欧美精选午夜久久久乱码6080| 久久精品视频在线| 欧美一区二区性|