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

隨筆 - 31  文章 - 128  trackbacks - 0
<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

常用鏈接

留言簿(5)

隨筆分類(38)

隨筆檔案(31)

收藏夾(4)

College

High School

最新隨筆

搜索

  •  

積分與排名

  • 積分 - 56709
  • 排名 - 407

最新評論

  • 1.?re: [yc]詳解link
  • 面試的時候面試官就問過我什么是編譯和鏈接,我說編譯就是把代碼文件生成目標文件,鏈接就是把目標文件生成可執行文件,他說不對,又問我什么是動態鏈接,還問我預編譯都做什么處理。。。都在這里找到了答案!!!!
  • --王至乾
  • 2.?re: [yc]詳解link
  • @劉偉
    我是說博主,不是叫你啊
  • --溪流
  • 3.?re: [yc]詳解link
  • 誰是石老師,我不是哈@溪流
  • --劉偉
  • 4.?re: [yc]詳解link
  • 石老師?我是溪流~
  • --溪流
  • 5.?re: [yc]詳解link
  • 期待樓主下文啊,多謝樓主了
  • --劉偉

閱讀排行榜

評論排行榜

    最近為了解析SQL語法,懷著試一試的心態去翻了翻boost的spirit庫,因為該庫的文檔的簡介里寫著LL parser framework  represents parsers directly as EBNF grammars in inlined C++。看著framework這個詞自然覺得這個庫很牛B,試用了一下果然如此。
    所謂EBNF即擴展巴克斯范式,是一種描述Context-Free Language的文法。在目前常見的非自然語言中,大部分都可以用EBNF表示。例如:
      group  ::='('exp
')'
      factor ::=integer|
group
      term   ::=factor(('*'factor)|('/'factor
))*
      exp    ::=term(('+'term)|('-'term
))*
這是一個整數表達式的EBNF。該段描述用spirit在C++中的實現則是:
   

   rule<> group, factor, term, exp;
   group  
= '(' >> exp >> ')';
   factor 
= int_p | group;
   term   
= factor >> *(('*' >> factor) | ('/' >> factor));
   exp    
= term >> *(('+' >> term) | ('-' >> term));

這里使用=代替::=, 用>>代替空格連接。并且由于C++語法所限,EBNF中后置的*在spirit中改為前置。
等式左邊的單詞被稱為一個rule,等式右邊為rule的定義。我們可以看出一個group是一個exp加上一對括號,一個factor是一個整數或者一個group,一個term是一個或多個factor用*/連接,一個exp是一個或多個term用+-連接。處于最頂端的exp可以據此識別出以下表達式
   

   12345
   
-12345
   
+12345
   
1 + 2
   
1 * 2
   
1/2 + 3/4
   
1 + 2 + 3 + 4
   
1 * 2 * 3 * 4
   (
1 + 2* (3 + 4)
   (
-1 + 2* (3 + -4)
   
1 + ((6 * 200- 20/ 6
   (
1 + (2 + (3 + (4 + 5))))

    得到一個rule之后,我們就可以用 parse函數對一個串進行識別了。例如
         

         parse( " (1 + (2 + (3 + (4 + 5)))) " , exp);


該函數返回一個結構parse_info,可以通過訪問其中的full成員來判斷是否成功識別,也可以訪問stop成員來獲知失敗的位置。這里要特別提一點,關于各個符號之間的空格,spirit的文檔的正文說的是給parse再傳一個參數space_p,通知parse跳過所有的空格,然而在FAQ中又提到,如果使用以上方法定義rule,第三個參數傳space_p會失敗。原因是使用rule默認定義的規則被稱為character level parsing,即字符級別解析,而parse的第3個參數僅適用于phrase level parsing,即語法級別解析。要使用第3個參數可以有幾種方法。
      1。在parse的第二個參數直接傳入一個EBNF表達式,不創建rule對象。
         

            parse( " hello world " * anychar_p, space_p);  


      2。以rule<phrase_scanner_t>創建rule。
         

            rule < phrase_scanner_t >  exp; 

注意雖然可以用這兩個辦法屏蔽空格,但是這樣可能完全改變EBNF文法的語義,尤其是在語言本身需要識別空格的時候。對于這種情況,可以不使用第三個參數,并在需要出現空格的地方加上space_p,或者+space_p及*space_p,其中+和*分別表示后面的符號連續出現一次以上和0次以上。例如一個以空格分隔的整數列表可以寫成int_p >> *(+space_p >> int_p)
   如上使用parse可以識別一個串,但并不能做更多的操作,例如將語法里的各個成分提取出來。對于這樣的需求,可以通過actor實現。下面是使用actor的一個簡單例子
   

   bool
   parse_numbers(
char const* str, vector<double>& v)
   
{
      
return parse(str,

   
//  Begin grammar
      (
         real_p[push_back_a(v)] 
>> *(',' >> real_p[push_back_a(v)])
      )
      ,
      
//  End grammar
      space_p).full;
   }

注意到real_p后面的[],中括號里面是一個仿函數(函數指針或者函數對象),該仿函數具有如下調用型別
   

   void operator()(IterT first, IterT last) const;
   
void operator()(NumT val) const;
   
void operator()(CharT ch) const;


一旦spase發現了匹配real_p的子串,就會調用該functor。不同的rule可能會對應不同的調用型別。
第一個型別針對一般規則,first和last為兩個指向字符的迭代器(一般為char*),匹配的子串為[first, last)
第二個型別針對數字型規則,如real_p和int_p, 參數val是一個數字類型。
第三個性別針對單字符型規則,如space_p, 參數ch是一個字符類型。
real_p[push_back_a(v)]中的push_back_a是一個spirit已經定義好的functor,它會將匹配好的內容依照匹配到的時間順序調用v的push_back函數加入到v中。

   到此spirit的常用功能就都介紹完了。要詳細深入了解可以參考spirit的文檔。

最后在題一個注意要點。spirit的各種EBNF連接都是指針連接,因此才能在expression被賦值前就在group的定義里面使用。所以在使用EBNF的時候一定要小心不要將局部變量的rule提供給全局或者類成員變量使用,例如:
   

   class A
   
{
      rule
<> s;
      A()
      
{
         rule
<> r = int_p | hex_p;

         s 
= r >> *(+space_p >> r); //error, r destructed after return 
      }

   }
;

如果真想使用局部作用域,可以在局部的rule前面加上static.

posted on 2005-12-18 12:02 shifan3 閱讀(7151) 評論(5)  編輯 收藏 引用 所屬分類: templateBoostC++

FeedBack:
# re: boost::spirit初體驗 2005-12-18 20:22 Windreamer Is Not DREAMER
贊,華麗的石老師
沒想到spirit竟然這么厲害??
看來我真得系統的把Boost好好看一遍,走馬觀花的看一圈真是暴殄天物啊

順便來踩踩地方~~~~~~~
沙發~~~~~~~~~~~~~~~~~~  回復  更多評論
  
# re: boost::spirit初體驗 2006-02-15 20:02 firestorm
我現在也在為一個oracle sql的簡單解析重組而煩惱!考慮使用lex和yacc,但是時間不太允許,想找個免費的數據庫的源碼看看,發現都不是很好用的哪種。
郁悶~  回復  更多評論
  
# re: boost::spirit初體驗 2006-09-13 19:51 manzheng

不懂,但還是re一下

~~~~~~~~~  回復  更多評論
  
# re: [yc]boost::spirit初體驗 2007-12-25 17:18 aaaaaaaaaa
英文閱讀太累,看到這個感覺沒那么冷了~~~~~  回復  更多評論
  
# re: [yc]boost::spirit初體驗 2007-12-25 17:20 aaaaaaaaaa
英文終究還是要看的,但有類似這種中文介紹做預習,感覺好多了,再頂~~~~~~  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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| 久久精品在线观看| 亚洲美女福利视频网站| 国产精品一区二区三区成人| 欧美在线视频一区二区| 欧美刺激午夜性久久久久久久| 日韩亚洲欧美精品| 麻豆国产精品va在线观看不卡| 亚洲黄网站黄| 亚洲一区欧美二区| 在线观看日韩欧美| 国产精品观看| 久久精品国产清自在天天线| 亚洲激情电影中文字幕| 性色av一区二区三区在线观看| 在线观看日韩国产| 国产伦精品一区二区三区免费 | 欧美精品久久久久久久久老牛影院| 亚洲精品美女91| 玖玖在线精品| 欧美亚洲综合久久| 欧美日韩黄视频| 国产视频一区欧美| 91久久精品国产91久久性色tv| 一区二区日韩伦理片| 久久av一区二区三区漫画| 美脚丝袜一区二区三区在线观看| 亚洲激情第一区| 午夜一区二区三视频在线观看| 开心色5月久久精品| 欧美日韩综合在线| 在线观看三级视频欧美| 亚洲一区在线直播| 麻豆精品在线观看| 亚洲男女自偷自拍| 欧美激情综合在线| 99re6这里只有精品| 久久最新视频| 一区二区三区欧美成人| 久久综合亚州| 国产精品日本精品| 亚洲精品一区二区三区福利| 午夜在线a亚洲v天堂网2018| 免费国产自线拍一欧美视频| 这里只有精品视频| 欧美高清hd18日本| 黑人巨大精品欧美黑白配亚洲| 亚洲一区二区三区三| 麻豆九一精品爱看视频在线观看免费| 亚洲免费观看高清在线观看| 欧美高清免费| 欧美国产三区| 亚洲黄色在线观看| 日韩亚洲欧美成人| 国产精品99久久久久久有的能看| 一区二区三区国产在线| 亚洲无线视频| 午夜日韩视频| 久久亚洲精选| 欧美精品 日韩| 欧美午夜片在线免费观看| 国产精品资源| 激情成人综合| 亚洲精品视频在线观看网站 | 久久一二三区| 欧美激情2020午夜免费观看| 欧美精品导航| 国产精品免费观看视频| 国产一区在线观看视频| 亚洲国产一区二区三区青草影视| 激情综合亚洲| 亚洲精品免费一二三区| 亚洲欧美变态国产另类| 欧美中文在线观看| 欧美 日韩 国产 一区| 日韩午夜剧场| 久久国产精品第一页| 欧美交受高潮1| 国产一区二区三区在线观看精品 | 国产在线乱码一区二区三区| 亚洲国产精品尤物yw在线观看| 一本色道久久88亚洲综合88| 欧美在线视频播放| 亚洲欧洲一区二区天堂久久| 亚洲图片激情小说| 久久人人97超碰国产公开结果| 久久久人成影片一区二区三区观看 | 午夜在线观看免费一区| 久久嫩草精品久久久精品一| 国产精品国产三级国产aⅴ无密码| 狠狠久久亚洲欧美| 亚洲男人天堂2024| 亚洲国产女人aaa毛片在线| 亚洲影院高清在线| 老巨人导航500精品| 国产精品无码永久免费888| 亚洲国产另类久久久精品极度| 久久精品99久久香蕉国产色戒| 91久久精品国产91久久性色| 久久爱www久久做| 欧美日韩日本网| 亚洲精品一区二区三区在线观看 | 亚洲在线免费观看| 欧美激情一区二区三级高清视频| 欧美性开放视频| 夜夜精品视频| 欧美大片一区二区| 久久久精品视频成人| 国产精品主播| 羞羞答答国产精品www一本| 亚洲国产精品一区| 性欧美暴力猛交69hd| 欧美日精品一区视频| 在线观看的日韩av| 一区二区三区国产精品| 久久久久久综合| 亚洲美女淫视频| 亚洲欧洲一区二区三区在线观看| 国产日韩欧美综合在线| 亚洲韩国日本中文字幕| 国内一区二区三区在线视频| 制服丝袜激情欧洲亚洲| 一区二区不卡在线视频 午夜欧美不卡'| 久久精品国产清高在天天线 | 日韩视频免费观看| 亚洲美女性视频| 欧美久久影院| 亚洲经典三级| 99国内精品久久| 欧美精品日韩| 日韩午夜中文字幕| 亚洲专区在线视频| 国产精品久久77777| 一区二区三区你懂的| 亚洲免费综合| 国产模特精品视频久久久久| 亚洲欧美日本另类| 国产亚洲成精品久久| 午夜一区不卡| 国产欧美91| 欧美一区二区三区视频免费播放| 香蕉尹人综合在线观看| 国产日韩欧美| 久久夜色精品国产| 亚洲欧洲一区二区天堂久久| 亚洲一区二区三区在线播放| 国产伦理一区| 久久中文字幕一区| 亚洲裸体俱乐部裸体舞表演av| 亚洲午夜激情| 国产一区二区高清视频| 免费欧美视频| 99国产精品久久久久久久成人热| 亚洲综合精品自拍| 激情文学一区| 欧美久色视频| 香蕉久久夜色| 欧美黑人一区二区三区| 亚洲午夜精品17c| 国内精品久久久久久 | 欧美成人资源| 亚洲欧美资源在线| 在线观看91精品国产麻豆| 欧美日韩国产综合网| 欧美专区一区二区三区| 亚洲人成欧美中文字幕| 欧美一区二区成人6969| 亚洲国产日韩综合一区| 国产精品久久久久久久久婷婷 | 蜜臀久久99精品久久久久久9| 99视频精品全国免费| 久久免费一区| 亚洲一区二区三区在线视频| 好吊妞**欧美| 欧美精品国产一区| 性欧美办公室18xxxxhd| 女仆av观看一区| 欧美一区午夜精品| 亚洲午夜精品久久久久久app| 亚洲国产成人不卡| 国产精品v一区二区三区| 性做久久久久久免费观看欧美| 久久婷婷国产综合国色天香| 国产美女精品视频| 美女视频一区免费观看| 一区二区三区蜜桃网| 欧美~级网站不卡| 亚洲专区一区| 亚洲欧洲精品一区二区三区波多野1战4 | 亚洲在线一区二区三区| 亚洲激情在线| 欧美激情视频网站| 久热这里只精品99re8久| 欧美一区二区三区精品| 一本色道久久综合亚洲精品按摩 |