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

隨筆-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精品国产福利在线观看免费| 亚洲国产毛片完整版| 欧美三级特黄| 久久久免费av| 欧美日韩国产在线播放| 午夜精品视频在线观看一区二区| 午夜视频在线观看一区| 一区二区三区在线观看国产| 亚洲黄色高清| 国产综合久久久久久| 欧美成人蜜桃| 国产精品成人在线| 麻豆精品在线视频| 欧美午夜久久久| 男人插女人欧美| 国产精品久久久久久久久久尿| 久久精品二区| 欧美日韩国产综合一区二区| 久久精品国产成人| 欧美日韩国产91| 久久影音先锋| 国产精品激情av在线播放| 久久人人爽人人爽爽久久| 欧美天堂亚洲电影院在线观看| 久久伊人精品天天| 国产女主播一区二区| 日韩亚洲视频在线| 在线观看国产精品淫| 亚洲影院色在线观看免费| 亚洲国产欧美在线| 性高湖久久久久久久久| 在线一区欧美| 欧美成人精品一区二区| 久久精品成人欧美大片古装| 欧美日韩综合视频网址| 欧美黄色免费网站| 好看的日韩视频| 亚洲欧美综合网| 性高湖久久久久久久久| 欧美日韩中文字幕在线视频| 亚洲国产精品va在线观看黑人| 国产日韩欧美视频在线| 亚洲社区在线观看| 一本一本久久a久久精品综合妖精 一本一本久久a久久精品综合麻豆 | 欧美日韩调教| 91久久线看在观草草青青| 在线观看欧美日本| 久久精品论坛| 久久一二三国产| 激情久久综艺| 久久久之久亚州精品露出| 久久露脸国产精品| 久久se精品一区二区| 欧美日韩色一区| 亚洲国产黄色| 亚洲国产综合91精品麻豆| 欧美中文字幕不卡| 另类综合日韩欧美亚洲| 激情综合色丁香一区二区| 欧美一区午夜视频在线观看| 久久成人精品电影| 国产一区二区剧情av在线| 欧美亚洲一级| 久久综合九色综合久99| 亚洲第一在线综合网站| 久久婷婷麻豆| 亚洲激情综合| 亚洲图片欧美日产| 国产乱码精品一区二区三区五月婷 | 亚洲在线播放电影| 国产精品人人爽人人做我的可爱 | 亚洲午夜一区| 久久av一区二区三区亚洲| 国产欧美成人| 美女精品在线| 一本大道久久a久久精二百| 亚洲免费在线观看视频| 国产一级一区二区| 六十路精品视频| 一本一本久久a久久精品牛牛影视| 亚洲一区二区三区涩| 国产拍揄自揄精品视频麻豆| 久久婷婷国产综合精品青草| 亚洲黄色大片| 久久精品国产第一区二区三区| 亚洲成在线观看| 欧美视频一区二区| 久久精品视频免费| 亚洲美女中文字幕| 久久青草福利网站| 中文国产成人精品久久一| 国产亚洲精品久久久| 免费日韩av片| 亚洲中字在线| 亚洲经典在线看| 久久成人国产| 亚洲小说春色综合另类电影| 国产主播精品| 欧美视频在线不卡| 欧美二区在线播放| 久久av免费一区| 99热在这里有精品免费| 老司机免费视频一区二区| 亚洲午夜精品一区二区| 永久免费毛片在线播放不卡| 国产精品www.| 欧美国产精品v| 久久米奇亚洲| 亚洲欧美在线x视频| 亚洲精品综合久久中文字幕| 老司机免费视频一区二区| 性做久久久久久免费观看欧美| 日韩视频国产视频| 伊人色综合久久天天| 国产精品主播| 欧美亚韩一区| 欧美日韩在线免费观看| 免费不卡视频| 久久久久亚洲综合| 欧美在线免费| 一本到12不卡视频在线dvd| 欧美一区二区在线视频| 亚洲成人在线网站| 激情综合视频| 国产一区二区三区日韩欧美| 国产精品久久午夜夜伦鲁鲁| 欧美日韩国产综合网| 欧美日韩免费在线| 欧美日韩成人网| 欧美激情中文字幕乱码免费| 免费观看一区| 欧美大成色www永久网站婷| 久久亚洲春色中文字幕| 久久久久久久波多野高潮日日 | av成人免费在线| 亚洲精品网址在线观看| 亚洲人体偷拍| 亚洲精品在线二区| 99re国产精品| 亚洲一级片在线观看| 亚洲亚洲精品在线观看| 亚洲一区二区三区乱码aⅴ蜜桃女| 一区二区三区视频在线| 亚洲永久免费| 久久gogo国模裸体人体| 久久亚洲午夜电影| 欧美黄色大片网站| 国产精品国产一区二区| 国产麻豆精品久久一二三| 国产亚洲综合性久久久影院| 激情欧美一区二区三区| 最新亚洲电影| 亚洲综合欧美| 久久五月天婷婷| 亚洲国产精品久久91精品| 亚洲精品一二三| 午夜视频在线观看一区| 久久综合久久久| 欧美日韩另类国产亚洲欧美一级| 国产精品萝li| 伊人婷婷久久| 亚洲免费在线观看视频| 老司机成人网| 在线视频日韩精品| 久久亚洲捆绑美女| 欧美午夜视频网站| 加勒比av一区二区| 宅男精品视频| 老巨人导航500精品| 99精品欧美| 久久女同精品一区二区| 欧美天堂亚洲电影院在线观看| 国产主播一区二区三区四区| 日韩网站免费观看| 久久一区二区三区av| 中文欧美日韩| 欧美成人黄色小视频| 国产视频久久久久久久| 亚洲精品一区二| 久久久久久香蕉网| 在线亚洲自拍| 欧美大片网址| 在线观看中文字幕亚洲| 午夜精品网站| 日韩亚洲不卡在线| 老司机午夜精品| 国产一区二区日韩| 亚洲砖区区免费| 亚洲人成艺术| 欧美成人午夜激情视频| 精品福利av|