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

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

常用鏈接

留言簿(5)

隨筆分類(38)

隨筆檔案(31)

收藏夾(4)

College

High School

最新隨筆

搜索

  •  

積分與排名

  • 積分 - 56680
  • 排名 - 407

最新評(píng)論

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

閱讀排行榜

評(píng)論排行榜

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

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

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

   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))))

    得到一個(gè)rule之后,我們就可以用 parse函數(shù)對(duì)一個(gè)串進(jìn)行識(shí)別了。例如
         

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


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

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


      2。以rule<phrase_scanner_t>創(chuàng)建rule。
         

            rule < phrase_scanner_t >  exp; 

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

   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后面的[],中括號(hào)里面是一個(gè)仿函數(shù)(函數(shù)指針或者函數(shù)對(duì)象),該仿函數(shù)具有如下調(diào)用型別
   

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


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

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

最后在題一個(gè)注意要點(diǎn)。spirit的各種EBNF連接都是指針連接,因此才能在expression被賦值前就在group的定義里面使用。所以在使用EBNF的時(shí)候一定要小心不要將局部變量的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 閱讀(7150) 評(píng)論(5)  編輯 收藏 引用 所屬分類: template 、Boost 、C++

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

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

不懂,但還是re一下

~~~~~~~~~  回復(fù)  更多評(píng)論
  
# re: [yc]boost::spirit初體驗(yàn) 2007-12-25 17:18 aaaaaaaaaa
英文閱讀太累,看到這個(gè)感覺沒那么冷了~~~~~  回復(fù)  更多評(píng)論
  
# re: [yc]boost::spirit初體驗(yàn) 2007-12-25 17:20 aaaaaaaaaa
英文終究還是要看的,但有類似這種中文介紹做預(yù)習(xí),感覺好多了,再頂~~~~~~  回復(fù)  更多評(píng)論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              亚洲视频国产视频| 亚洲精品网站在线播放gif| 亚洲午夜精品17c| 国产日韩欧美精品在线| 性色av一区二区怡红| 国产精品任我爽爆在线播放| 亚洲免费一级电影| 亚洲一区亚洲二区| 国内精品美女av在线播放| 欧美成人一区二区三区| 欧美紧缚bdsm在线视频| 亚洲影院一区| 亚洲欧美日本视频在线观看| 激情综合电影网| 欧美激情1区2区| 欧美激情综合在线| 欧美一区二区视频免费观看| 久久精品国产精品亚洲| 亚洲人成绝费网站色www| 99精品视频免费观看| 国产麻豆日韩欧美久久| 欧美国产精品日韩| 欧美亚洲成人网| 久久久精品一品道一区| 女女同性精品视频| 亚洲欧美视频一区| 久久野战av| 亚洲欧美在线网| 美腿丝袜亚洲色图| 欧美一级日韩一级| 欧美顶级少妇做爰| 久久久久国产一区二区三区| 欧美国产日韩二区| 久久久亚洲精品一区二区三区| 欧美精品九九| 久久女同互慰一区二区三区| 欧美日韩免费高清一区色橹橹| 欧美一区二区三区在线观看| 欧美激情一区二区在线| 久久久久久9999| 国产精品久久一区二区三区| 亚洲国产成人久久综合| 国产免费成人| 亚洲天堂成人在线观看| 亚洲毛片在线免费观看| 久久综合久色欧美综合狠狠| 欧美一区综合| 国产精品久久久一本精品| 亚洲国产另类久久精品| 亚洲国产高清高潮精品美女| 欧美在线亚洲综合一区| 香蕉久久夜色| 国产精品www994| 亚洲免费av观看| 一本色道久久综合亚洲精品小说| 久久青青草综合| 久久视频在线看| 国内自拍视频一区二区三区| 亚洲调教视频在线观看| 中日韩男男gay无套| 欧美日本在线| 日韩视频―中文字幕| 99在线精品视频| 欧美成人精品在线视频| 欧美高清视频一二三区| 亚洲国产日韩欧美| 亚洲欧洲偷拍精品| 欧美不卡视频| 免费美女久久99| 亚洲第一精品福利| 另类激情亚洲| 亚洲第一中文字幕| 亚洲精品一区在线| 欧美日韩国产精品自在自线| 日韩一级在线| 欧美一级午夜免费电影| 国产欧美日韩伦理| 欧美在线日韩| 欧美大片免费久久精品三p| 亚洲国产欧美日韩精品| 欧美日韩国产综合网| 日韩视频在线观看| 欧美一区二区三区视频在线| 国产在线精品成人一区二区三区 | 欧美精品v国产精品v日韩精品 | 亚洲免费在线电影| 国产欧美va欧美va香蕉在| 欧美在线电影| 亚洲激情社区| 亚洲男人的天堂在线观看 | 免费黄网站欧美| 99热精品在线| 久久免费视频观看| 亚洲免费观看在线观看| 国产噜噜噜噜噜久久久久久久久 | 亚洲国产美女| 亚洲欧美视频在线观看视频| 狠狠久久五月精品中文字幕| 欧美 亚欧 日韩视频在线| 亚洲美女诱惑| 美女黄毛**国产精品啪啪| 一本久道久久久| 国内精品国语自产拍在线观看| 欧美国产极速在线| 午夜精品久久久久久久| 亚洲片在线观看| 久久福利视频导航| 亚洲美女91| 精品99视频| 国产精一区二区三区| 免费人成精品欧美精品| 欧美一区二区三区久久精品| 亚洲国产色一区| 噜噜噜噜噜久久久久久91| 亚洲午夜视频| 亚洲精品久久7777| 国内自拍亚洲| 国产精品久久久久9999高清| 久久亚洲国产精品一区二区| 亚洲午夜精品国产| 亚洲精选一区二区| 亚洲高清不卡在线观看| 久久这里只有精品视频首页| 欧美亚洲自偷自偷| 亚洲欧美成人在线| 一区二区三区欧美视频| 亚洲国产专区| 在线观看国产日韩| 国产一区深夜福利| 国产精品推荐精品| 欧美婷婷久久| 欧美日韩在线视频一区二区| 蜜桃av久久久亚洲精品| 久久久久久久综合| 久久精品中文字幕一区二区三区| 亚洲深夜激情| 国语自产精品视频在线看抢先版结局| 欧美午夜影院| 国产精品久久久久av| 欧美三级午夜理伦三级中视频| 欧美激情视频网站| 欧美激情综合五月色丁香| 欧美福利小视频| 免费av成人在线| 美女尤物久久精品| 欧美精品www在线观看| 欧美理论片在线观看| 欧美精品在线视频| 欧美日韩视频一区二区| 欧美调教视频| 国产精品视频一区二区三区 | 欧美亚洲免费| 久久久99久久精品女同性 | 亚洲乱亚洲高清| 99re热精品| 亚洲自拍偷拍色片视频| 午夜精品久久久久久久久| 欧美在线综合| 久久亚洲精选| 欧美人与性动交α欧美精品济南到| 欧美人与禽性xxxxx杂性| 欧美日韩在线观看一区二区| 国产精品久久久久久久午夜 | 欧美日韩卡一卡二| 国产精品久久久免费| 国产日产亚洲精品| 亚洲高清激情| 亚洲一二三区在线观看| 久久精品123| 欧美国产一区视频在线观看| 亚洲精品久久久久久久久久久| 亚洲一区二区成人在线观看| 久久精品视频99| 欧美剧在线观看| 国产欧美精品| 亚洲美女在线一区| 欧美一区二区三区啪啪| 欧美暴力喷水在线| 亚洲最新合集| 久久久综合激的五月天| 欧美揉bbbbb揉bbbbb| 国模叶桐国产精品一区| 国产精品99久久久久久白浆小说| 久久久亚洲一区| 99国内精品久久久久久久软件| 欧美在线高清| 欧美精品一级| 狠狠狠色丁香婷婷综合久久五月| 中文日韩在线视频| 美女精品在线| 亚洲综合第一页| 欧美精品一区二区三| 国产日韩精品一区二区| 这里只有精品丝袜| 免费不卡亚洲欧美| 午夜一级久久| 国产精品久久久久久久久免费| 亚洲九九精品| 六十路精品视频| 欧美一区二区三区四区视频|