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

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

其中,關于優先級的設計有點迷惑,參考了網上關于Pascal操作符優先級后,文法如下:

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"加減表達式缺少右操作數 =>"+ErrorInfomation.GetMessage());
21                    return 0;
22                }

23                LytPtr<Expression> Right=GetAndExpression(Current);
24                if (IsError())
25                {
26                    ErrorInfomation.SetMessage(L"加減表達式右操作數出錯 =>"+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表達式缺少右操作數 =>"+ErrorInfomation.GetMessage());
56                    return 0;
57                }

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

64                else Temp->Right=Right;
65            }

66            return Result;
67        }

68    }

69}

 

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

1.函數模板

2.函數指針:利用typedef,后來發現定義過程中有遞歸,遂寫不出來,暫時放棄

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

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

 

在構造表達式樹的時候還出現了幾個問題:

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

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

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

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

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

 

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

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

FeedBack:
# re: 初步完成表達式樹
2009-03-22 01:29 | 陳梓瀚(vczh)
4:將操作符的優先級放在一個數組里面,然后設計一個通用算法解決。  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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久久精品国产91久久性色| 久久精品亚洲乱码伦伦中文 | 免费在线观看成人av| 亚洲黄色在线视频| 亚洲国产日韩欧美一区二区三区| 欧美日韩国产在线观看| 亚洲一区观看| 欧美专区在线观看| 亚洲免费成人| 欧美一区二区三区在| 亚洲欧洲一区二区三区在线观看 | 久久国产福利| 欧美xart系列高清| 欧美一区二区网站| 久久久夜精品| 亚洲女同精品视频| 久久伊伊香蕉| 午夜精品久久久久| 久久综合一区二区| 亚洲欧美日韩在线一区| 久久久噜噜噜久噜久久 | 1000精品久久久久久久久| 亚洲人妖在线| 国产亚洲一区在线| 亚洲精品久久久久久一区二区| 国产精品亚洲欧美| 亚洲国产精品久久人人爱蜜臀 | 国产一区二区久久精品| 亚洲国产成人av| 国产欧美亚洲一区| 日韩亚洲精品电影| 91久久在线观看| 欧美一区免费视频| 亚洲午夜精品17c| 免费观看在线综合色| 久久黄色级2电影| 欧美日韩一区二区三区在线观看免| 久久久噜噜噜久久| 国产精品a久久久久| 亚洲高清成人| 亚洲电影一级黄| 久久国产欧美日韩精品| 亚洲欧美成aⅴ人在线观看| 免费一级欧美片在线观看| 久久精品国产99国产精品| 国产精品电影在线观看| 91久久综合| 亚洲人成毛片在线播放女女| 久久久精品国产免大香伊| 欧美区高清在线| 亚洲一区区二区| 欧美日韩精品三区| 欧美高清你懂得| 亚洲高清不卡在线观看| 久久久精品一区| 久久久久久久久久久成人| 国产精品亚洲综合| 亚洲一区二区三区激情| 亚洲综合第一| 国产精品日本欧美一区二区三区| 一片黄亚洲嫩模| 亚洲视频图片小说| 欧美视频中文字幕在线| 国产精品99久久久久久久久久久久 | 欧美精品在线视频| 亚洲美女中文字幕| 亚洲夜间福利| 国产精品日本欧美一区二区三区| 亚洲少妇最新在线视频| 亚洲欧美日韩中文播放| 国产麻豆91精品| 久久精品国产99| 欧美华人在线视频| 夜夜嗨av一区二区三区网站四季av| 欧美精品一区二区三区在线播放 | 国产综合第一页| 久久天天躁狠狠躁夜夜爽蜜月| 欧美国产亚洲精品久久久8v| 亚洲成色www8888| 欧美精品一区二区三区四区| 99热这里只有精品8| 香蕉久久夜色精品国产使用方法 | 欧美日韩激情小视频| 一区二区三区视频在线观看 | 亚洲一区二区三区四区中文| 国产日产亚洲精品系列| 久久影院午夜片一区| 亚洲精品一区二区三区在线观看 | 久久最新视频| 日韩亚洲欧美成人| 国产精品亚洲а∨天堂免在线| 久久国产88| 99re6热只有精品免费观看| 久久狠狠一本精品综合网| 亚洲人人精品| 国产一级精品aaaaa看| 免费欧美在线| 亚洲欧美在线高清| 亚洲国产成人久久| 香蕉久久国产| 亚洲视频电影图片偷拍一区| 国产综合久久久久久| 欧美日韩国产成人在线91| 欧美一级视频免费在线观看| 最新国产乱人伦偷精品免费网站| 久久久不卡网国产精品一区| 先锋影音网一区二区| 亚洲国产一区二区三区高清| 国产精品福利在线观看| 蘑菇福利视频一区播放| 亚洲免费在线观看视频| 91久久精品日日躁夜夜躁国产| 久久成年人视频| 亚洲图片激情小说| 亚洲日本欧美天堂| 国产在线精品成人一区二区三区| 欧美日韩中文在线| 免费观看成人www动漫视频| 香蕉久久一区二区不卡无毒影院 | 欧美伦理91i| 久久精品在线观看| 性18欧美另类| 亚洲尤物影院| 亚洲天天影视| 一本久道久久综合婷婷鲸鱼| 亚洲精华国产欧美| 免费视频亚洲| 麻豆成人在线观看| 久久久久99| 久久精品麻豆| 久久精品人人做人人综合| 亚洲欧美国产一区二区三区| 亚洲午夜极品| 亚洲欧美一区二区原创| 亚洲影视中文字幕| 亚洲综合不卡| 午夜在线电影亚洲一区| 午夜精品偷拍| 久久福利毛片| 久久青青草原一区二区| 久久婷婷麻豆| 猛男gaygay欧美视频| 美国三级日本三级久久99| 玖玖视频精品| 欧美激情第9页| 亚洲国产岛国毛片在线| 亚洲人成网站色ww在线| 亚洲精品国产精品久久清纯直播| 亚洲精品视频一区二区三区| 亚洲精品在线观看视频| 亚洲精品一区二区三区蜜桃久| 一区二区毛片| 亚洲永久网站| 久久er99精品| 美国十次了思思久久精品导航| 欧美ed2k| 国产精品久久久久久户外露出| 国产乱码精品1区2区3区| 国产亚洲欧美日韩一区二区| 精品动漫av| 99视频在线观看一区三区| 在线亚洲精品| 久久久91精品国产| 亚洲电影第三页| 一区二区不卡在线视频 午夜欧美不卡在| 亚洲视频精选在线| 欧美专区在线播放| 欧美精品激情blacked18| 国产精品女主播一区二区三区| 国产亚洲精品v| 亚洲精品免费一区二区三区| 亚洲欧美一区二区三区在线 | 夜夜爽av福利精品导航| 久久国产婷婷国产香蕉| 91久久精品国产91久久性色tv| 亚洲视频香蕉人妖| 久久在线播放| 国产精品一区久久| 亚洲日本欧美在线| 久久精品网址| 日韩视频在线观看| 欧美亚男人的天堂| 午夜激情一区| 亚洲国产一区二区三区高清| 亚洲视频观看| 欧美国产先锋| 国内精品视频久久| 亚洲一区影院| 亚洲国产裸拍裸体视频在线观看乱了| 亚洲影视在线| 欧美日韩综合精品| 亚洲区中文字幕| 欧美顶级艳妇交换群宴| 欧美一区二区三区免费观看视频| 欧美日韩国产精品一区二区亚洲| 尤物九九久久国产精品的分类|