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

隨筆-341  評論-2670  文章-0  trackbacks-0
    上一篇文章中我們看到了可配置語法分析器使用起來的樣子,在這篇文章中我將告訴大家如何通過重載操作符的方法構造文法表達式樹,從而使用遞歸向下法進行語法分析的工作。

    在這之前我們將研究一下什么是文法表達式。我們將文法表達式看成分析器,于是復雜的文法表達式就是由簡單的分析器通過各種方法組合起來的復雜分析器。一個分析器有以下幾個屬性:

    1:輸入類型。輸入類型通常是一個字符串的指針還是迭代器什么的,具體類型不重要,重要的是輸入狀態必須能被復制,能跳到下一個元素。當然wchar_t*也滿足這種要求,但是我們為了通用性(譬如可以為你自己的容器擴展出一個輸入迭代器)我們采用類似STL的迭代器的方法,也就是concept(這并沒有包含其技巧,只是概念)來實現。然后庫將為一些基本的東西提供默認的迭代器,譬如IEnumerable<T>(嗯嗯,這不是C#,已經被Vczh Library++實現了。容器采用了一種泛型+接口的方法,但是在不必要的情況下允許不支付虛函數的代價,不過這根本章內容無關,以后再談),或者WString和AString。

    2:輸出類型。輸出類型一般包含兩個方面。第一個是成功后的結果,第二個是失敗后的錯誤信息。怎么讓可配置語法分析器在恰當的地方輸出類型也是一個很復雜的問題,不過這根本章內容無關,下一篇文章接著講這個細節。在這里我們先忽略錯誤信息,就如同正則表達式拒絕匹配一個字符串也不會告訴你為什么一樣。

    我們可以通過這兩種屬性來構造出一個文法表達式的基類。表達式樹通常用基類+若干子類的方法來實現,有了基類等于定下了子類的基調。
1 template<typename I, typename O>
2 class Expression
3 {
4 public:
5   virtual Maybe<O> Parse(I& input)=0;
6 };

    Maybe指的是里面可以有類型O的值,或者什么都沒有。這額外的信息可以添加一個bool來表達,這里就不贅敘了。到了這里我們明白一個表達式樹的重點不是其內容,而是分析輸入的算法。因此我們可以組合出連接、分支和循環:
 1 template<typename I, typename O1, typename O2>
 2 class Sequence : public Expression<I, ParsingPair<O1, O2>>;
 3 {
 4 public:
 5   Ptr<Expression<I, O1>> left;
 6   Ptr<Expression<I, O2>> right;
 7 
 8   Maybe<ParsingPair<O1, O2>> Parse(I& input);
 9 };
10 
11 template<typename I, typename O>
12 class Alternate : public Expression<I, O>;
13 {
14 public:
15   Ptr<Expression<I, O>> left;
16   Ptr<Expression<I, O>> right;
17 
18   Maybe<O> Parse(I& input);
19 };
20 
21 template<typename I, typename O>
22 class Loop : public Expression<I, ParsingList<O>>;
23 {
24 public:
25   Ptr<Expression<I, O>> element;
26   int min;
27   int max;
28 
29   Maybe<ParsingList<O>> Parse(I& input);
30 };

    這就是連接、分支和循環的聲明了?,F在我們可以很清楚的了解什么是帶類型的文法了。類型主要指的是輸出類型,而輸入類型肯定是不能變化的。ParsingPair<A, B>就是一個帶兩個數據的結構,而ParsingList<T>是一個鏈表。做成這樣主要是為了在傳遞他們的時候不要做太多浪費的復制工作,在這里我們只需要了解其概念就好了。

    每一種組合都對子文法的類型有著一些要求,譬如說分支要求左右文法表達式的類型是一樣的。而且輸出類型是通過子文法的類型計算而得到的。Ptr<T>是智能指針,在這里使用主要是為了避免復制的時候出現問題。智能指針在這種數據結構下還是十分好用的,反正構造和析構一條文法的效率都是無關緊要的,不要太慢就可以了。

    但是我們如何重載操作符來組合文法表達式呢?其實文法表達式最終產生的結果都是Ptr<Expression<I, O>>,Ptr的操作符重載是不能修改的,所以我們還要一個代理類:
 1 template<typename I, typename O>
 2 class Node
 3 {
 4 public:
 5   Ptr<Expression<I, O>> expression;
 6 };
 7 
 8 template<typename I, typename O>
 9 Node<I, O> operator|(const Node<I, O>& left, const Node<I, O>& right);
10 
11 template<typename I, typename O1, typename O2>
12 Node<I, ParsingPair<O1, O2>> operator+(const Node<I, O1>& left, const Node<I, O2>& right);
13 
14 //除了+以外,還可以繼承*啊,或者干脆寫個loop(node, min, max)什么的
15 template<typename I, typename O>
16 Node<I, ParsingList<O>> operator+(const Node<I, O>& element);

    我們就可以在每一個操作符重載里面將各自Node的expression成員變量拿出來,然后通過構造上面提供的Sequence、Alternate和Loop來構造更加復雜的文法表達式,最后重新裝進一個Node<I, O>里面就行了。

    這就是我們可以將文法寫進C++的小技巧。下一篇文章我們將會了解到表達式的每一個Parse函數內部都做了些什么。
posted on 2009-12-04 23:43 陳梓瀚(vczh) 閱讀(3220) 評論(1)  編輯 收藏 引用 所屬分類: VL++3.0開發紀事

評論:
# re: Vczh Library++ 3.0之可配置語法分析器(設計文法表達式) 2009-12-05 06:59 | radar
精辟??!  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            欧美激情自拍| 国产一区二区三区奇米久涩| 99国内精品久久久久久久软件| 久久亚洲精品中文字幕冲田杏梨| 欧美在线黄色| 欧美在线视频一区二区三区| 亚洲精品久久久久久久久久久久久 | 亚洲欧美一区二区激情| 午夜精品99久久免费| 麻豆久久久9性大片| 麻豆精品视频在线| 欧美激情精品久久久久久黑人 | 亚洲欧洲一级| 日韩午夜在线观看视频| 这里只有视频精品| 久久av一区二区| 牛牛国产精品| 国产精品成人一区二区艾草| 国产精品一区二区在线观看不卡 | 国产精品久久久久久av福利软件 | 国产婷婷色一区二区三区| 精品1区2区3区4区| 亚洲乱码日产精品bd| 午夜天堂精品久久久久| 欧美成人国产va精品日本一级| 最新中文字幕亚洲| 欧美一级在线视频| 欧美日韩1区2区3区| 狠狠爱成人网| 亚洲欧美日韩一区二区在线 | 欧美一级黄色网| 欧美电影免费网站| 亚洲欧美国产精品桃花| 欧美v国产在线一区二区三区| 国产精品久久福利| 亚洲精品美女免费| 久久青草欧美一区二区三区| 亚洲精选一区| 狼人社综合社区| 国产欧美日韩在线观看| 一区二区精品国产| 欧美韩日亚洲| 欧美综合国产| 国产精品视频福利| 亚洲视频图片小说| 亚洲国产成人精品久久久国产成人一区 | 亚洲欧美不卡| 亚洲欧洲一区二区在线观看| 久久丁香综合五月国产三级网站| 欧美日韩在线一区二区| 老司机精品久久| 亚洲一区久久| 欧美激情无毛| 91久久精品日日躁夜夜躁国产| 久久精品视频va| 亚洲无线视频| 国产精品久久久久一区| 宅男噜噜噜66一区二区66| 亚洲国产日韩欧美在线图片 | 国产精品久久国产精麻豆99网站| 亚洲精品综合精品自拍| 欧美大片一区| 欧美+亚洲+精品+三区| 亚洲第一偷拍| 欧美成人高清视频| 久久只有精品| 91久久精品日日躁夜夜躁国产| 麻豆精品视频在线| 老司机午夜免费精品视频 | 香蕉亚洲视频| 亚洲一区二区免费看| 国产精品理论片| 午夜精品久久久久久久99黑人| 一区二区高清| 国产精品亚洲网站| 久久久久久久久久久一区| 久久国产主播精品| 亚洲国产日韩综合一区| 亚洲激情第一区| 国产精品va| 欧美在线视频播放| 久久久久久91香蕉国产| 亚洲激情在线播放| 日韩五码在线| 国产亚洲欧美另类一区二区三区| 久久中文字幕一区二区三区| 久久婷婷激情| 日韩一级精品| 亚洲欧美国内爽妇网| 精品999成人| 亚洲国产精品久久久久| 欧美日韩视频在线观看一区二区三区| 亚洲综合不卡| 久久久久久午夜| 在线亚洲+欧美+日本专区| 欧美一级视频精品观看| 99精品国产99久久久久久福利| 亚洲桃花岛网站| 在线播放精品| 中文国产成人精品| 亚洲高清电影| 亚洲一区二区三区在线观看视频| 精品福利电影| 一区二区三区国产在线| 尤物视频一区二区| 亚洲午夜羞羞片| 亚洲国产精品久久久久婷婷老年 | 欧美日韩一区二区在线观看视频| 亚洲精品中文字幕女同| 亚洲在线一区| 亚洲国产精品久久久久秋霞影院| 一区二区三区 在线观看视频| 一区二区视频欧美| 亚洲午夜激情网站| 亚洲人成高清| 久久国产欧美| 香蕉精品999视频一区二区 | 欧美一区二区三区在| 免费在线看一区| 久久久精品一区| 欧美午夜精品久久久久久孕妇| 裸体女人亚洲精品一区| 国产精品久久久| 亚洲靠逼com| 在线视频国产日韩| 欧美一区二区免费| 亚洲一二三四区| 欧美激情中文字幕一区二区| 麻豆精品传媒视频| 国产午夜精品久久久| 亚洲性xxxx| 亚洲影院免费| 欧美喷潮久久久xxxxx| 欧美激情中文不卡| 亚洲精品黄色| 欧美大片在线看| 欧美激情一区二区三区| 亚洲人妖在线| 欧美激情一区二区三区蜜桃视频| 欧美成人自拍视频| 亚洲国产mv| 欧美成人激情在线| 亚洲欧洲视频在线| 亚洲色诱最新| 国产精品久久久一区二区| 亚洲视频第一页| 欧美一区二区三区日韩| 国产日韩一级二级三级| 午夜精品久久久久久| 欧美在线播放一区二区| 国产欧美日韩高清| 欧美一区精品| 欧美福利电影网| 日韩视频在线观看免费| 欧美日韩精品不卡| 亚洲免费在线看| 久久免费视频这里只有精品| 亚洲第一网站| 欧美性色综合| 性做久久久久久免费观看欧美| 六月婷婷久久| 亚洲婷婷在线| 国内久久视频| 欧美精品七区| 亚洲一区三区电影在线观看| 久久久国产视频91| 亚洲美女毛片| 国产精品一区二区a| 久久久久一区二区三区| 亚洲欧洲一区二区三区| 欧美一区二区三区成人| 亚洲国产老妈| 亚洲欧美日韩一区在线| 久久综合国产精品| 亚洲美女黄网| 国产欧美日韩一级| 欧美国产一区二区| 亚洲男人的天堂在线观看 | 久色成人在线| 99riav久久精品riav| 国产欧美视频一区二区三区| 欧美成年网站| 欧美一区二区三区免费看 | 亚洲三级影院| 国产精品视频免费观看www| 久久在线播放| 亚洲主播在线| 亚洲国产精品免费| 久久精品国产久精国产爱| 99爱精品视频| 1000精品久久久久久久久| 国产嫩草影院久久久久| 欧美理论在线播放| 久久综合给合久久狠狠狠97色69| 亚洲一区一卡| 一本色道久久综合亚洲精品不 | 亚洲国产精品国自产拍av秋霞| 久久精品官网| 亚洲欧美日韩另类精品一区二区三区 | 在线一区二区三区四区五区|