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

Lyt
posts - 16,comments - 61,trackbacks - 0

 

今天使用智能指針LytPtr初步完成了表達式樹,未調試完全,頭文件代碼如下:

 1class Interpret
 2{
 3public:
 4  Error ErrorInfomation;
 5
 6  bool IsError();
 7  LytPtr<Program> Run(const LytWString Content);
 8
 9private:
10  LytPtr<Program> GetProgram(Node<Token*>*& Current);
11  LytPtr<Function> GetFunction(Node<Token*>*& Current);
12  LytPtr<Var> GetVar(Node<Token*>*& Current);
13  LytPtr<Block> GetBlock(Node<Token*>*& Current);
14  LytPtr<FunHead> GetFunHead(Node<Token*>*& Current);
15  LytPtr<FunHead> GetFunctionHead(Node<Token*>*& Current);
16  LytPtr<FunHead> GetProcedureHead(Node<Token*>*& Current);
17  LytPtr<Statement> GetStatement(Node<Token*>*& Current);
18  LytPtr<Statement> GetAssignStatementOrSimpleStatement(Node<Token*>*& Current);
19  LytPtr<Statement> GetIfStatement(Node<Token*>*& Current);
20  LytPtr<Statement> GetWhileDoStatement(Node<Token*>*& Current);
21  LytPtr<Statement> GetDoWhileStatement(Node<Token*>*& Current);
22  LytPtr<Statement> GetControlStatement(Node<Token*>*& Current);
23  LytPtr<Statement> GetReturnStatement(Node<Token*>*& Current);
24  LytPtr<Statement> GetCompoundStatement(Node<Token*>*& Current);
25  LytPtr<Expression> GetExpression(Node<Token*>*& Current);
26  LytPtr<Expression> GetRelationExpression(Node<Token*>*& Current);
27  LytPtr<Expression> GetXorExpression(Node<Token*>*& Current);
28  LytPtr<Expression> GetOrExpression(Node<Token*>*& Current);
29  LytPtr<Expression> GetAddSubExpression(Node<Token*>*& Current);
30  LytPtr<Expression> GetAndExpression(Node<Token*>*& Current);
31  LytPtr<Expression> GetMulDivExpression(Node<Token*>*& Current);
32  LytPtr<Expression> GetPositiveNegativeExpression(Node<Token*>*& Current);
33  LytPtr<Expression> GetNotExpression(Node<Token*>*& Current);
34  LytPtr<Expression> GetSimpleExpression(Node<Token*>*& Current);
35  LytPtr<Expression> GetCallFunctionExpression(Node<Token*>*& Current);
36}
;

其中,關于優(yōu)先級的設計有點迷惑,參考了網(wǎng)上關于Pascal操作符優(yōu)先級后,文法如下:

Expression = RelationExpression;
RelationExpression = RelationExpression ("<" | "<=" | "=" | "!=" | ">" | ">=") XorExpression | XorExpression
XorExpression = XorExpression "xor" OrExpression | OrExpression
OrExpression = OrExpression "or" AddExpression | AddSubExpression
AddSubExpression = AddSubExpression ("+" | "-") AndExpression | AndExpression
AndExpression = AndExpression "and" MulDivExpression | MulDivModExpression
MulDivModExpression = MulDivModExpression ("*" | "div" | "mod") UnaryExpression | UnaryExpression
PositiveNegativeExpression = ("+" | "-") NotExpression | NotExpression
NotExpression = "not" SimpleExpression | SimpleExpression;
SimpleExpression = Number | bool | CallFunctionExpression

代碼舉例:

 1LytPtr<Expression> GetAddSubExpression(Node<Token*>*& Current)
 2{
 3    if (!Current) return 0;
 4    else
 5    {
 6        LytPtr<Expression> Result=GetAndExpression(Current);
 7        if (IsError()) return 0;
 8        else
 9        {
10            while (Current && (Current->Data->Content==L"+" || Current->Data->Content==L"-"))
11            {
12                LytPtr<Expression> Left=Result;
13                Result=new BinaryExpression;
14                BinaryExpression* Temp=(BinaryExpression*)Result.Buffer();
15                Temp->Left=Left;
16                Temp->Operator=*(Current->Data);
17                Current=Current->Next;
18                if (!Current)
19                {
20                    ErrorInfomation.SetMessage(L"加減表達式缺少右操作數(shù) =>"+ErrorInfomation.GetMessage());
21                    return 0;
22                }

23                LytPtr<Expression> Right=GetAndExpression(Current);
24                if (IsError())
25                {
26                    ErrorInfomation.SetMessage(L"加減表達式右操作數(shù)出錯 =>"+ErrorInfomation.GetMessage());
27                    return 0;
28                }

29                else Temp->Right=Right;
30            }

31            return Result;
32        }

33    }

34}

35
36LytPtr<Expression> GetMulDivExpression(Node<Token*>*& Current)
37{
38    if (!Current) return 0;
39    else
40    {
41        LytPtr<Expression> Result=GetPositiveNegativeExpression(Current);
42        if (IsError()) return 0;
43        else
44        {
45            while (Current && (Current->Data->Content==L"*" || Current->Data->Content==L"div"))
46            {
47                LytPtr<Expression> Left=Result;
48                Result=new BinaryExpression;
49                BinaryExpression* Temp=(BinaryExpression*)Result.Buffer();
50                Temp->Left=Left;
51                Temp->Operator=*(Current->Data);
52                Current=Current->Next;
53                if (!Current)
54                {
55                    ErrorInfomation.SetMessage(L"*/div表達式缺少右操作數(shù) =>"+ErrorInfomation.GetMessage());
56                    return 0;
57                }

58                LytPtr<Expression> Right=GetPositiveNegativeExpression(Current);
59                if (IsError())
60                {
61                    ErrorInfomation.SetMessage(L"*/div表達式右操作數(shù)出錯 =>"+ErrorInfomation.GetMessage());
62                    return 0;
63                }

64                else Temp->Right=Right;
65            }

66            return Result;
67        }

68    }

69}

 

不難發(fā)現(xiàn),含有二元操作符的表達式文法接近(一元也一樣),函數(shù)實現(xiàn)方法也類似,為了讓代碼好看點,我動了幾個念頭,但最終沒實現(xiàn):

1.函數(shù)模板

2.函數(shù)指針:利用typedef,后來發(fā)現(xiàn)定義過程中有遞歸,遂寫不出來,暫時放棄

3.宏:記得括號來括號去那里要加得很清楚,腦袋暈乎,暫時放棄

晚上睡覺能想到啥好辦法明天再解決。

 

在構造表達式樹的時候還出現(xiàn)了幾個問題:

1.先前由于我沒有充分測試,LytPtr有bug,自食其果了

結論:寫出啥數(shù)據(jù)結構在使用前一定要充分測試

2.猶豫到底該用返回什么類型的指針,暫時還不明白返回LytPtr<Expression>與返回LytPtr<Base>的區(qū)別,其中Expression是繼承Base的

3.LytPtr不支持類型轉換,于是在需要類型轉換的時候愣了幾下,忘記可以轉成指針來用了

結論:該用指針的時候還是用指針

 

希望明天完成測試表達式樹與類型檢查。

posted on 2009-03-22 00:55 Lyt 閱讀(574) 評論(1)  編輯 收藏 引用 所屬分類: Pascal簡化版

FeedBack:
# re: 初步完成表達式樹
2009-03-22 01:29 | 陳梓瀚(vczh)
4:將操作符的優(yōu)先級放在一個數(shù)組里面,然后設計一個通用算法解決。  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            免费在线成人av| 亚洲激精日韩激精欧美精品| 欧美不卡视频一区发布| 亚洲激情视频网站| 国产日本精品| 久久精品成人一区二区三区| 亚洲靠逼com| 麻豆精品精华液| 午夜精品影院| 中日韩男男gay无套| 黑人极品videos精品欧美裸| 国产精品久久久久久久久久直播 | 欧美福利一区| 久久久久久精| 久久深夜福利| 欧美乱妇高清无乱码| 久久综合九色综合久99| 免费日韩av电影| 欧美电影免费网站| 亚洲在线第一页| 欧美在线观看日本一区| 久久婷婷丁香| 亚洲精品久久久久久久久久久久| 亚洲精品中文字幕女同| 亚洲欧美日本伦理| 美腿丝袜亚洲色图| 国产精品一级久久久| 激情一区二区三区| 亚洲一二三级电影| 欧美高清视频在线播放| 亚洲综合成人在线| 欧美福利视频一区| 激情综合久久| 亚洲欧美日韩综合国产aⅴ| 欧美成人午夜激情视频| 性欧美8khd高清极品| 久久精品国产亚洲精品| 欧美黑人一区二区三区| 在线高清一区| 久久色在线观看| 欧美中文在线观看| 国产一区二区三区四区在线观看| 午夜精品久久久久影视| 一区二区三区四区五区在线| 欧美三级小说| 久久爱www.| 久久精品国产精品亚洲| 精品福利免费观看| 欧美国产一区二区| 欧美大片在线影院| 亚洲视屏在线播放| 亚洲人成7777| 中文无字幕一区二区三区| 久久综合狠狠综合久久综青草| 国产精品久久久久久久9999 | 免费观看成人网| 久久国产精品黑丝| 欧美日韩成人综合在线一区二区 | 亚洲视频精品| 欧美绝品在线观看成人午夜影视 | 亚洲第一黄网| 蜜臀91精品一区二区三区| 国产性色一区二区| 久久久99免费视频| 久久国产精品久久久| 欧美日韩国产不卡在线看| 亚洲精品1234| 亚洲一二三区在线观看| 国产一区二区电影在线观看| 久久成人羞羞网站| 久久久久99精品国产片| 亚洲国产成人精品久久久国产成人一区| 久久久精品999| 欧美精品在线视频观看| 亚洲欧美日本国产有色| 性欧美精品高清| 夜夜嗨av一区二区三区四季av| 亚洲精品美女| 激情久久中文字幕| 一区二区三区欧美激情| 韩国成人理伦片免费播放| 亚洲精品免费看| 极品日韩久久| 欧美一区二区在线免费播放| 亚洲精品看片| 欧美一区二区三区在线观看| 亚洲天堂黄色| 欧美精品18+| 美女黄毛**国产精品啪啪| 欧美激情一区二区三区全黄| 久久精品99无色码中文字幕| 国产精品亚洲第一区在线暖暖韩国| 亚洲成人在线视频播放| 精品福利电影| 美女精品自拍一二三四| 麻豆成人在线观看| 亚洲第一黄色网| 日韩视频免费| 国产精品video| 日韩视频免费| 亚洲免费在线观看视频| 久久精品国产91精品亚洲| 亚洲欧美视频一区二区三区| 久久日韩粉嫩一区二区三区| 久久一区二区三区四区五区| 国产一区二区在线观看免费| 久久精品成人一区二区三区| 久久综合色婷婷| 亚洲人成网在线播放| 欧美日本在线| 香蕉久久a毛片| 欧美福利在线| 亚洲欧美国产不卡| 韩日成人av| 欧美三级在线视频| 久久成人国产| 欧美一区午夜视频在线观看| 亚洲国产精品黑人久久久| 欧美日韩精品免费观看视频完整 | 久久男人av资源网站| 亚洲精选大片| 免费在线欧美视频| 亚洲一区999| 99精品国产一区二区青青牛奶| 欧美91精品| 噜噜爱69成人精品| 午夜免费日韩视频| 日韩亚洲不卡在线| 欧美电影打屁股sp| 久久九九99| 久久精品日韩欧美| 午夜精品www| 亚洲欧美不卡| 午夜国产一区| 久久久久在线观看| 狂野欧美激情性xxxx欧美| 91久久夜色精品国产九色| 国产主播一区二区| 欧美精品乱码久久久久久按摩| 久久久精品一区| 麻豆免费精品视频| 老司机一区二区| 亚洲天堂免费在线观看视频| 亚洲国产日韩欧美| 99国产精品视频免费观看一公开| 亚洲二区精品| 在线不卡免费欧美| 99国产精品| 久久九九全国免费精品观看| 久久亚洲精品视频| 日韩一区二区精品在线观看| 亚洲视频在线观看| 久久九九热免费视频| 欧美日韩亚洲一区二| 国产美女精品在线| 亚洲国产成人午夜在线一区| 欧美亚洲视频在线看网址| 欧美第一黄网免费网站| 99re热精品| 欧美成人精品在线视频| 国产网站欧美日韩免费精品在线观看| 激情久久五月| 久久综合九色综合欧美就去吻| 99re视频这里只有精品| 久久久久久精| 亚洲人成亚洲人成在线观看 | 欧美中文字幕不卡| 久久久av水蜜桃| 久久精品国产成人| 国产欧美精品久久| 日韩一级不卡| 亚洲精品久久久久久一区二区| 亚洲免费观看在线视频| 久久夜色精品一区| 国产香蕉久久精品综合网| 日韩亚洲在线观看| 亚洲永久免费视频| 久久久五月婷婷| 欧美国产综合视频| 日韩视频在线观看| 国产精品香蕉在线观看| 欧美一区二区三区四区视频| 久久综合久久综合久久| 亚洲精品乱码久久久久久按摩观| 欧美日韩精品一区二区三区四区| 亚洲小少妇裸体bbw| 久久视频精品在线| 亚洲精品综合久久中文字幕| 国产精品五区| 欧美黄色aa电影| 久久成人一区| 亚洲视频视频在线| 亚洲国产精品www| 欧美综合国产| 亚洲少妇中出一区| 亚洲黑丝在线| 黄色在线一区| 国产欧美日韩高清| 欧美视频专区一二在线观看| 免费在线看一区|