• <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>
            隨筆-91  評論-137  文章-0  trackbacks-0
            我們先了看下Alt組合子的分析代碼
             1     virtual O Parser(I& input)
             2     {
             3         I temp = input;
             4         if(O Result = left.Parser(input)) return Result;
             5         input = temp;
             6         if(O Result = right.Parser(input)) return Result;
             7         input = temp;
             8         O Result(GetMM());
             9         return Result;
            10     }
            當left分析失敗時會將原先的input值重新賦值給input,但此時并沒有改變SymbolStack和StringStack,應此當第一次分析失敗時SymbolStack和StringStack中會包含一些重復的值.當然其他組合子同樣存在這個問題.
            應此我為CParser_Input增加了兩個成員變量保存此時的SymbolStack和StringStack的Size,當SymbolStack和StringStack Push的時候同時增加input相應的值.
            最后重載CParser_Input的operator=賦值操作符,在其中根據原先的SymbolStack和StringStack的Size來彈出相應數量的重復值
             1     CParser_Input& operator=(CParser_Input& _value)
             2     {
             3         LexerTokenList = _value.LexerTokenList;
             4         index = _value.index;
             5 
             6         if(_value.symbolCount < symbolCount && _value.symbolCount)
             7         {
             8             int Count = symbolCount - _value.symbolCount;
             9             for(int i=0;i<Count;i++) SymbolStack.Pop();
            10         }
            11 
            12         if(_value.stringCount < stringCount && _value.stringCount)
            13         {
            14             int Count = stringCount - _value.stringCount;
            15             for(int i=0;i<Count;i++) StringStack.Pop();
            16         }
            17 
            18         symbolCount = SymbolStack.Size();
            19         stringCount = StringStack.Size();
            20         return *this;
            21     }
            以此來解決SymbolStack和StringStack的同步問題.
            posted on 2011-07-10 22:13 lwch 閱讀(1131) 評論(0)  編輯 收藏 引用 所屬分類: QLanguage
            天天爽天天狠久久久综合麻豆| 狠狠色婷婷久久一区二区| 久久久久AV综合网成人| 国产韩国精品一区二区三区久久| 久久棈精品久久久久久噜噜| 久久久精品免费国产四虎| 国产精品久久久久乳精品爆| 久久综合九色综合网站| 久久er99热精品一区二区| 国产福利电影一区二区三区久久久久成人精品综合 | 国产精品九九久久免费视频 | 久久人人爽人人爽人人片AV东京热| 久久久国产精华液| 久久久久综合网久久| 2021国产精品久久精品| 亚洲综合精品香蕉久久网97 | av色综合久久天堂av色综合在| 久久不射电影网| 国产aⅴ激情无码久久| 91精品国产色综久久 | 久久久中文字幕| 一本久久a久久精品亚洲| 99久久精品国产一区二区| 国内精品久久久久久99蜜桃| 婷婷久久综合九色综合九七| 日本一区精品久久久久影院| 亚洲欧洲日产国码无码久久99| 久久久久综合中文字幕 | 欧洲精品久久久av无码电影| 久久激情五月丁香伊人| 精品久久久久久久| 久久综合九色综合网站| 久久精品国产2020| 久久人人爽人人爽人人片AV高清 | 性欧美丰满熟妇XXXX性久久久| 精品久久国产一区二区三区香蕉| 国产精品久久久久9999高清| 久久精品国产亚洲精品2020| 久久精品国产精品亚洲毛片| …久久精品99久久香蕉国产| 久久国产精品99国产精|