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

隨筆-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) 閱讀(1432) 評論(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>
            在线亚洲成人| 久久免费黄色| 性欧美xxxx视频在线观看| 亚洲一区国产视频| 亚洲人体影院| 亚洲伦理精品| 乱码第一页成人| 欧美一区不卡| 国产日韩欧美三区| 欧美亚洲一区三区| 一区二区日韩伦理片| 欧美在线地址| 国产欧美欧洲在线观看| 亚洲网站视频| 亚洲欧洲一区二区在线播放| 久久久久久亚洲综合影院红桃 | 久久精品国产亚洲aⅴ| 中日韩高清电影网| 国产精品国产三级国产普通话蜜臀| 日韩亚洲不卡在线| 亚洲欧洲精品一区| 欧美高清在线视频观看不卡| 久热这里只精品99re8久| 在线免费观看日本一区| 欧美成人免费播放| 欧美日韩精品高清| 欧美亚洲日本国产| 久久久免费精品| 亚洲国产影院| 一区二区精品| 国户精品久久久久久久久久久不卡| 久久精品夜色噜噜亚洲aⅴ| 久久婷婷国产麻豆91天堂| 亚洲精品视频在线观看网站 | 久久亚洲精品视频| 欧美一级在线视频| 激情视频一区二区| 91久久国产综合久久| 欧美日韩国产999| 午夜视黄欧洲亚洲| 欧美一区综合| 亚洲精品视频在线观看网站| 中文一区在线| 在线成人亚洲| 中日韩美女免费视频网址在线观看 | 99在线观看免费视频精品观看| 欧美一区影院| 在线观看日韩一区| 亚洲精品之草原avav久久| 欧美三日本三级少妇三99| 亚洲欧美激情一区二区| 99综合在线| 欧美一区二区视频免费观看| 欧美视频福利| 久久久青草婷婷精品综合日韩 | 日韩视频在线观看国产| 国产精品视频第一区| 你懂的视频欧美| 欧美午夜视频在线观看| 久久综合久久久久88| 欧美日韩国产色综合一二三四| 久久精品二区| 欧美日韩综合| 亚洲第一色中文字幕| 国产精品视频免费一区| 欧美激情五月| 国语自产精品视频在线看| 日韩视频在线观看免费| 在线观看三级视频欧美| 亚洲女同同性videoxma| 一本色道久久88亚洲综合88| 美女视频黄 久久| 久久综合给合久久狠狠色| 国产精品一级| 9色国产精品| 一区二区激情| 欧美精品久久久久a| 你懂的视频一区二区| 国产综合在线视频| 亚洲欧美亚洲| 欧美一区二区精美| 欧美亚洲成人网| 亚洲另类一区二区| 日韩一区二区免费高清| 欧美3dxxxxhd| 亚洲电影免费在线 | 亚洲国产欧美一区二区三区同亚洲| 亚洲淫片在线视频| 国产欧美一区二区精品婷婷| 亚洲午夜精品| 性色一区二区| 国产精品一级二级三级| 亚洲一本大道在线| 国产欧美一区二区三区久久| 亚洲一区二区三区精品视频| 亚洲综合丁香| 国产欧美一区二区精品忘忧草| 亚洲天堂男人| 欧美亚洲视频在线看网址| 国产精品久久久久三级| 亚洲影音一区| 久久久午夜精品| 亚洲电影在线免费观看| 嫩草伊人久久精品少妇av杨幂| 女女同性精品视频| 亚洲国产精品成人综合色在线婷婷| 久久久久久久久久码影片| 男女视频一区二区| 亚洲靠逼com| 欧美午夜大胆人体| 欧美一区二区日韩一区二区| 久久男人资源视频| 亚洲乱码一区二区| 国产精品日日做人人爱| 久久精品欧美日韩| 欧美激情一区二区| 这里只有精品视频在线| 欧美一区三区二区在线观看| 国产日韩av高清| 另类亚洲自拍| 日韩午夜黄色| 亚洲人成7777| 亚洲欧美日韩天堂| 国产日韩欧美在线视频观看| 久久人人爽国产| 亚洲精品久久久一区二区三区| 一区二区国产日产| 韩国av一区二区三区| 欧美日韩国产不卡| 久久精品一区二区国产| 亚洲乱码国产乱码精品精98午夜| 久久国产精品久久国产精品| 亚洲精品精选| 国产伦精品一区二区三区视频孕妇 | 欧美日韩1234| 亚洲男女自偷自拍| 亚洲国产精品福利| 亚洲一区二区在线免费观看视频| 国内精品嫩模av私拍在线观看| 欧美高清在线一区二区| 亚洲欧美日韩在线不卡| 亚洲国产精品久久| 久久精品日产第一区二区三区| 亚洲精品乱码久久久久久日本蜜臀| 国产精品欧美一区喷水| 老司机精品久久| 欧美亚洲在线播放| 亚洲免费av电影| 蜜臀久久久99精品久久久久久| 亚洲欧美国产77777| 亚洲美女一区| 亚洲国产精品尤物yw在线观看 | 亚洲欧美经典视频| 99精品欧美一区二区蜜桃免费| 激情综合电影网| 国产精品久久久久久久免费软件| 免费视频最近日韩| 久久久久久久久岛国免费| 亚洲在线视频观看| 亚洲免费av片| 亚洲人精品午夜在线观看| 欧美激情影音先锋| 欧美顶级大胆免费视频| 美国成人直播| 免费不卡亚洲欧美| 老司机免费视频一区二区三区| 久久精品一区二区三区中文字幕| 欧美一区二区三区视频| 性做久久久久久免费观看欧美| 亚洲欧美日韩另类精品一区二区三区| 在线视频欧美日韩| 亚洲永久精品大片| 亚洲欧美日韩一区二区在线| 亚洲一区二三| 欧美亚洲一区二区在线观看| 欧美在线视频一区| 久久噜噜噜精品国产亚洲综合| 久久久另类综合| 久久九九国产| 免费久久久一本精品久久区| 麻豆av一区二区三区| 久久综合伊人77777麻豆| 久久婷婷麻豆| 欧美日韩精品在线视频| 国产精品高潮呻吟久久av无限| 美日韩精品视频| 欧美不卡视频一区| 欧美大片在线观看一区| 欧美激情精品久久久久久大尺度| 欧美成年人在线观看| 欧美精品久久久久久久久老牛影院| 欧美激情一区二区三区高清视频 | 欧美国产日韩视频| 欧美女同视频| 国产精品美女一区二区| 国产日韩在线视频| 亚洲第一在线综合在线| 亚洲精选视频免费看| 亚洲午夜电影| 久久精品国内一区二区三区|