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

隨筆-341  評論-2670  文章-0  trackbacks-0

除了錯誤處理文件還沒有定義好以外,現在語法定義跟語法樹的數據結構定義以及分析器都完成了!有了這兩個文件,我的工具就可以替你生成一個函數和一堆類,讓你使用這個函數就可以將一份代碼轉換為一顆語法樹啦。娃哈哈……

 

現在讓我們來看一個例子,這個例子展示了一個科學計算器的表達式的結構定義以及語法定義。首先是數據結構的定義:

enum BinopType

{

  Plus

  Minus

  Mul

  Div

}

enum SinopType

{

  Negative

}

 

class Expression

{

}

class Number Expression

{

  double                              Number

}

class Binop Expression

{

  BinopType                      Operator

  Expression^                   LeftOp

  Expression^                   RightOp

}

class Sinop Expression

{

  SinopType                       Operator

  Expression^                   Operand

}

class Invoke Expression

{

  string                               Name;

  list<Expression^>         Parameters;

}

 

Type^的意思是autoptr<Type>。因為語義已經決定了這玩意兒是生成樹的,所以我們不需要考慮循環引用的問題。如果你不改動這個樹的話,你可以不必刪除,autoptr自己會將這些問題處理掉的。內存管理是一件多么麻煩的事情啊,于是我解決掉了。class后面的第一個名稱是類名,如果第二個名稱存在的話則代表父類的類名,可以用來表達繼承關系。

 

那么現在看看語法的定義:

num                   ="\d+(.\d+)?"            ;

ident                  ="[a-zA-Z_]\w*"       ;

plus                    ="\+"                           ;

minus                ="\-"                                     ;

mul                    ="\*"                           ;

div                      ="/"                             ;

leftbrace           ="\("                                     ;

rightbrace        ="\)"                                     ;

comma              =","                             ;

discard              ="\s+"                         ;

 

Number^                    factor=num{Number};

Sinop^                         factor=minus{Operator=Negative} factor{Operand};

Expression^               factor=leftbrace exp{#result} rightbrace;

Invoke^                       factor=ident{Name}[leftbrace param_list{Parameters} rightbrace];

Expression^               term =factor{#result};

Binop^                       term=term{LeftOp} (mul{Operator=Mul}|div{Operator=Div}) factor{RightOp};

Expression^               exp=term{#result};

Binop^                        exp=exp{LeftOp} (plus{Operator=Plus}|minus{Operator=Minus}) term{RightOp};

list<Expression^>    param_list=exp{#insert} [comma param_list{#result}];

Expression^               program=exp{#result};

 

我們來看其中的兩條文法。第一條文法:list<Expression^>param_list=exp{#insert}[comma param_list{#result}];。文法推導式子返回list<Expression^>類型的對象。如果param_list存在那么將param_list當成當前的列表,否則創建一個新列表。然后將exp使用insert方法插入列表的頭部。最后返回列表。

 

第二條文法:Binop^ exp=exp{LeftOp} (plus{Operator=Plus}|minus{Operator=Minus}) term{RightOp};。文法推導式子返回Binop^類型的對象。將exp放入成員LeftOp,將term放入成員RightOp,如果遇到plus則將Operator設置為BinopType::Plus,否則設置為BinopType::Minus。參考一下前面對于類Binop以及枚舉類型BinopType的定義就知道了。

 

文法從program開始,分析器檢查輸入的字符串,得到一個正確的推倒之后,就是用這些語義命令來構造所需的數據結構。當整個過程被生成為C++代碼之后,一切都變得非常的方便。等代碼生成部分完成之后(這一部分由于將產生基于我半年前做的Syngram庫的代碼,由于Syngram支持在C++里面直接寫文法,所以代碼生成是沒有什么難度的,而且做起來很快)就算不會處理字符串也可以寫文法分析器啦!

posted on 2008-09-14 00:53 陳梓瀚(vczh) 閱讀(1434) 評論(3)  編輯 收藏 引用 所屬分類: 腳本技術

評論:
# re: 語法分析器定義接近完成! 2008-09-14 00:56 | Real
博主辛苦了,那么多作品。  回復  更多評論
  
# re: 語法分析器定義接近完成! 2008-09-14 02:23 | jx
您可真是個強人,不知道你考研不?  回復  更多評論
  
# re: 語法分析器定義接近完成! 2008-09-14 03:14 | 陳梓瀚(vczh)
不考  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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热精品在线观看| 日韩一二三在线视频播| 欧美日韩国产精品成人| 亚洲女性裸体视频| 午夜视频在线观看一区| 韩国三级电影久久久久久| 久热国产精品| 欧美大片第1页| 亚洲一区二区三区激情| 午夜欧美精品久久久久久久| 亚洲第一福利在线观看| 亚洲精品裸体| 国产精品久久中文| 免费成人黄色| 欧美日韩一卡二卡| 久久久久久网址| 欧美激情一区二区三区全黄| 亚洲在线观看视频网站| 久久国产精品高清| 在线视频欧美日韩精品| 久久狠狠亚洲综合| 99成人在线| 久久精品国产精品亚洲综合| 99国内精品久久| 欧美制服丝袜| 亚洲特色特黄| 久久综合999| 午夜精品福利在线| 欧美激情第六页| 久久国产精品电影| 欧美久久久久免费| 久久综合电影一区| 国产精品久久激情| 亚洲国产欧美一区| 国模私拍一区二区三区| aa国产精品| 亚洲欧洲日产国产综合网| 一本在线高清不卡dvd| 91久久夜色精品国产九色| 亚洲女人天堂成人av在线| 99re6这里只有精品| 久久永久免费| 久久精品亚洲一区| 国产精品免费网站在线观看| 亚洲国产精品va在线观看黑人| 国产日韩欧美三级| 亚洲视频在线免费观看| 一区二区激情| 欧美福利在线观看| 欧美成人性网| 精品成人国产| 久久久99国产精品免费| 久久精品观看| 国产欧美一区二区视频| 亚洲一二三区在线观看| 亚洲性视频h| 欧美日韩精品一区| 亚洲裸体视频| 亚洲天堂av电影| 欧美视频导航| 亚洲午夜精品一区二区三区他趣| 在线视频日韩精品| 欧美体内谢she精2性欧美| 在线视频日本亚洲性| 亚洲在线视频一区| 国产精品爽爽ⅴa在线观看| 亚洲小说欧美另类社区| 午夜在线成人av| 国产日韩视频| 久久精品最新地址| 欧美激情片在线观看| 亚洲精品少妇| 欧美日韩一区自拍| 亚洲在线视频| 久久亚洲不卡| 亚洲精品欧美日韩专区| 欧美日韩另类视频| 亚洲视频精选| 久久久高清一区二区三区| 极品少妇一区二区三区| 米奇777超碰欧美日韩亚洲| 亚洲高清久久| 亚洲伊人伊色伊影伊综合网| 国产精品羞羞答答xxdd| 欧美一区二区在线免费观看| 久久夜色精品国产欧美乱极品| 亚洲国产老妈| 欧美手机在线| 久久精品在线播放| 亚洲精品偷拍| 久久九九全国免费精品观看| 亚洲精品一二区| 国产乱码精品一区二区三区av| 久久超碰97人人做人人爱| 亚洲国产成人一区| 在线视频欧美日韩| 韩国三级电影一区二区| 欧美精品综合| 午夜精品免费在线| 亚洲国产精品久久精品怡红院| 亚洲一区二区三区四区五区午夜| 国产日韩欧美亚洲| 欧美成人午夜| 欧美在线观看网址综合| 亚洲激情网址| 久久久国产精品亚洲一区| 99视频+国产日韩欧美| 国产亚洲精品久久久| 欧美日本二区| 看片网站欧美日韩| 亚洲综合日韩| 亚洲国产精品电影| 久久免费视频一区| 亚洲一区国产一区| 亚洲精品中文字幕在线观看| 国产午夜久久| 国产精品久久久久久超碰| 麻豆久久婷婷| 久久激情视频免费观看| 亚洲视频 欧洲视频| 亚洲激情午夜| 欧美国产日韩一区| 久久综合九色九九| 欧美怡红院视频一区二区三区| 99国产精品一区| 亚洲精选中文字幕| 亚洲国产精品久久久久| 国产在线精品二区| 国产手机视频精品| 国产精品色婷婷| 欧美性片在线观看| 欧美日韩国产成人在线91| 欧美极品在线播放| 欧美成人精品在线观看| 欧美成人高清视频| 久久综合久久久| 久久一区亚洲| 蜜臀av性久久久久蜜臀aⅴ| 久久久爽爽爽美女图片| 久久精品国产一区二区三| 午夜伦欧美伦电影理论片| 性欧美videos另类喷潮| 亚洲女同性videos| 午夜激情久久久| 欧美有码在线观看视频| 久久精品五月婷婷| 久久嫩草精品久久久精品一| 久久久亚洲高清| 久久亚洲视频| 欧美激情在线| 欧美视频在线免费| 国产精品久久久久久久久久三级| 欧美揉bbbbb揉bbbbb| 国产精品理论片在线观看| 国产精品一区免费观看| 国产一区二区三区高清播放| 激情综合五月天| 亚洲高清视频在线观看| 亚洲美女中文字幕| 亚洲一区高清| 久久综合给合久久狠狠色| 欧美不卡在线视频| 亚洲精品乱码久久久久久日本蜜臀 | 亚洲视频专区在线| 亚洲欧美日韩第一区| 欧美在线播放一区| 久久综合久久综合这里只有精品| 欧美 日韩 国产 一区| 亚洲人在线视频| 亚洲一区免费看| 久久久久成人精品免费播放动漫| 鲁大师影院一区二区三区| 欧美日韩国产限制| 国产夜色精品一区二区av| 亚洲国产日韩欧美在线图片| 中国女人久久久| 久久成人国产精品| 亚洲二区在线| 亚洲欧美视频在线| 欧美国产日韩在线观看| 国产精品综合av一区二区国产馆| 伊人色综合久久天天五月婷| 99国产精品久久久久久久成人热| 欧美亚洲免费| 亚洲国产成人av在线| 亚洲男人的天堂在线| 免费看精品久久片| 国产日韩欧美一区在线| 一本色道久久综合狠狠躁的推荐| 久久久久国产精品麻豆ai换脸| 亚洲人成高清| 久久久91精品国产一区二区精品| 欧美日韩日本视频| 亚洲日本激情| 玖玖国产精品视频| 亚洲一区三区视频在线观看| 欧美精品麻豆|