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

隨筆-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 };

    這就是連接、分支和循環的聲明了。現在我們可以很清楚的了解什么是帶類型的文法了。類型主要指的是輸出類型,而輸入類型肯定是不能變化的。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) 閱讀(3219) 評論(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>
            久久综合电影| 亚洲美女视频| 久久伊人亚洲| 亚洲国产欧美一区| 亚洲美女尤物影院| 国产精品乱码妇女bbbb| 久久国产精品99久久久久久老狼| 亚洲一区二区三区欧美| 国产三级欧美三级日产三级99| 久久偷看各类wc女厕嘘嘘偷窃| 另类春色校园亚洲| 亚洲午夜91| 欧美在线播放一区| 亚洲精品免费观看| 亚洲免费网站| 91久久综合| 亚洲视频导航| 最新国产精品拍自在线播放| 99精品欧美一区二区三区综合在线| 国产精品人人做人人爽| 毛片一区二区三区| 欧美性猛交xxxx免费看久久久 | 米奇777超碰欧美日韩亚洲| 免费成年人欧美视频| 亚洲欧美日韩在线播放| 久久视频这里只有精品| 午夜精品视频在线观看| 久久亚洲精品视频| 午夜精品一区二区三区四区| 久久久夜夜夜| 性久久久久久| 欧美巨乳在线观看| 蜜臀a∨国产成人精品| 国产精品video| 欧美激情在线观看| 国产丝袜一区二区| 夜夜嗨av一区二区三区四季av| 国产在线拍揄自揄视频不卡99| 亚洲欧洲精品一区二区| 狠狠网亚洲精品| 国产午夜亚洲精品不卡| 野花国产精品入口| 亚洲精品一线二线三线无人区| 久久都是精品| 欧美一区亚洲| 国产精品欧美一区二区三区奶水 | 亚洲久久一区| 亚洲人在线视频| 久久中文字幕导航| 另类图片国产| 很黄很黄激情成人| 欧美专区第一页| 欧美在线1区| 国产亚洲美州欧州综合国| 一区二区高清在线观看| 99精品视频一区| 欧美国产精品一区| 欧美激情一区二区三区四区| 亚洲电影视频在线| 玖玖精品视频| 欧美成人一区二区三区在线观看 | 久久激情一区| 国产午夜精品久久久久久久| 亚洲一区区二区| 午夜免费久久久久| 国产酒店精品激情| 欧美一区免费视频| 麻豆91精品| 亚洲激情在线观看| 欧美精品一区二区在线观看| 最新国产乱人伦偷精品免费网站 | 日韩视频免费观看| 欧美日韩国产黄| 一本色道久久88综合亚洲精品ⅰ| 一区二区久久| 国产精品露脸自拍| 欧美亚洲午夜视频在线观看| 久久久久久久久久久一区| 国内精品久久久久国产盗摄免费观看完整版| 午夜精品亚洲一区二区三区嫩草| 欧美呦呦网站| 亚洲韩国青草视频| 欧美日韩国产小视频| 亚洲一级在线观看| 免费日韩一区二区| 一本色道久久综合| 国产精品伊人日日| 久久久久久一区二区| 亚洲欧洲日韩综合二区| 性欧美videos另类喷潮| 一区二区亚洲| 欧美三级网址| 久久精品国产2020观看福利| 亚洲激情中文1区| 欧美伊久线香蕉线新在线| 亚洲电影在线看| 国产精品免费久久久久久| 久久精品视频在线播放| 日韩视频一区二区在线观看| 久久疯狂做爰流白浆xx| 亚洲美女精品久久| 国产精品一区=区| 欧美激情精品久久久久久大尺度| 亚洲一区日韩| 亚洲激情在线激情| 久久精品一区二区三区四区| 9人人澡人人爽人人精品| 国产欧美一级| 欧美三级视频在线播放| 久久综合九色综合网站 | 免费影视亚洲| 性8sex亚洲区入口| 洋洋av久久久久久久一区| 国内精品模特av私拍在线观看| 欧美日韩一区二区三区免费| 久久久夜色精品亚洲| 亚洲欧美日本另类| 国产麻豆一精品一av一免费| 99在线精品视频| 欧美jizzhd精品欧美喷水| 欧美与黑人午夜性猛交久久久| 夜夜狂射影院欧美极品| 在线免费不卡视频| 国产在线成人| 国产一区二区三区日韩欧美| 国产精品电影观看| 欧美国产先锋| 欧美成人激情视频免费观看| 久久中文字幕一区| 久久久久久尹人网香蕉| 久久成人av少妇免费| 亚洲伊人久久综合| 国产精品99久久久久久久女警| 亚洲毛片播放| 日韩一级大片在线| 99国内精品| 在线亚洲成人| 亚洲一区日本| 香蕉成人伊视频在线观看| 亚洲与欧洲av电影| 欧美一区二区三区的| 欧美怡红院视频一区二区三区| 欧美一区二区精美| 欧美一区二区观看视频| 久久精品99| 美女91精品| 欧美日韩成人一区二区三区| 欧美日韩国产一区| 国产精品白丝jk黑袜喷水| 国产精品女人网站| 国产视频一区免费看| 伊人成人开心激情综合网| 很黄很黄激情成人| 亚洲精品在线免费观看视频| 夜夜精品视频一区二区| 亚洲欧美日韩精品久久久| 欧美在线亚洲一区| 免费看黄裸体一级大秀欧美| 亚洲第一狼人社区| 一本色道精品久久一区二区三区 | 久久精品在线观看| 免费中文字幕日韩欧美| 亚洲国产精品99久久久久久久久| 亚洲精品中文在线| 午夜在线播放视频欧美| 美日韩精品免费| 国产精品成人一区| 狠狠色狠狠色综合日日tαg| 亚洲国产欧美不卡在线观看| 亚洲素人在线| 久久男人av资源网站| 亚洲三级电影在线观看| 亚洲影院高清在线| 免费成人高清在线视频| 国产精品福利在线观看| 精品动漫一区二区| 亚洲一区二区三区中文字幕在线| 久久九九99视频| 亚洲免费观看在线观看| 久久精品理论片| 欧美色123| 亚洲国产高清aⅴ视频| 午夜伦理片一区| 91久久在线观看| 久久久成人网| 国产精品久久久久久影院8一贰佰| 在线观看亚洲精品| 欧美一级视频| 亚洲精选在线观看| 狂野欧美激情性xxxx| 国产精品一二三| 夜夜嗨av色一区二区不卡| 久久在精品线影院精品国产| 一个人看的www久久| 欧美成人免费小视频| 韩国成人福利片在线播放| 午夜精品一区二区三区电影天堂| 亚洲高清久久久| 鲁大师成人一区二区三区 | 亚洲一区二区三区777|