欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > 正則表達式之回溯

正則表達式之回溯

熱門標簽:惠安地圖標注 浙江營銷外呼系統有哪些 上海銷售電銷機器人軟件 自己做的電銷機器人 地圖標注店鋪地圖標注酒店 遼寧秒客來電話機器人 山東外呼系統聯系方式 淄博市張店區地圖標注 哈爾濱公司外呼系統代理
關于“回溯”我也是第一次接觸,對它也不算很了解。下面就把我所了解的做為一個心德記錄下來,以備查看。

我們所使用的正則表達式的匹配基礎大概分為:優先選擇最左端(最靠開頭)的匹配結果和標準的匹配量詞(*、+、?和{m, n})是匹配優先的。

“優先選擇最左端的匹配”顧名思義就是從字符串的起始位置開始匹配直到匹配結束這是基礎;“標準匹配量詞”又分為“非確定型有窮自動機(NFA)”也可以叫做“表達式主導”;另外一種是“確定型有窮自動機(DFA)”也可以叫做“文本主導”。我們目前在JavaScript中所使用的正則表達式為“表達式主導”。表達式主導和文本主導解釋起來有些麻煩,先看來一個例子可能會清楚些。

復制代碼 代碼如下:

// 使用正則表達式匹配文本
var reg = /to(nite|knight|night)/;
var str = 'doing tonight';
reg.test(str);

在上面的這個例子中,第一個元素[t],它將會重復嘗試,直到目標字符串中找到‘t'為止。之后,就檢查緊隨其后的字符是否能由[o]匹配,如果能,就檢查下面的元素(nite|knight|night)。它的真正含義是“nite”或者“knight”或者“night”。引擎會依次嘗試這3種可能。嘗試[nite]的過程是先嘗試[n],然后[i],然后[t],最后是[e]。如果這種嘗試失敗,引擎會嘗試另一種可能,如此繼續下去,直到匹配成功或是報告失敗。表達式中的控制權在不同的元素之間轉換,所以稱為“表達式主導”。

    同樣是上面的例子“文本主導”在掃描字符串時,會記錄當前有效的所有匹配可。當引擎移動到t時,它會在當前處理的匹配可能中添加一個潛在的可能:

字符串中的位置 正則表達中的位置
……doing tonight 可能的匹配位置:/to(nite|knight|nigth)/

 

接下來掃描的每個字符,都會更新當前的可能匹配序列。繼續掃描兩個字符以后的情況是:

 

字符串中的位置 正則表達中的位置
……doing tonight 可能的匹配位置:/to(nite|knight|nigth)/

 

有效的可能匹配變為兩個(knight被淘汰出局)。掃描到g時,就只剩下一個可能匹配了。當h和t匹配完成后,引擎發現匹配已經完成,報告成功。“文本主導”是因為它掃描的字符串中的每個字符都對引擎進行了控制。

    如果想要弄明白“表達式主導”是如何工作的,那就要看一下我們今天的主題“回溯(backtracking)”。回溯就像是在走岔路口,當遇到岔路的時候就先在每個路口做一個標記。如果走了死路,就可以照原路返回,直到遇見之前所做過的標記,標記著還未嘗試過的道路。如果那條路也走不能,可以繼續返回,找到下一個標記,如此重復,直到找到出路,或者直到完成所有沒有嘗試過的路。

    在許多情況下,正則引擎必須在兩個(或更多)選項中做出選擇。當遇到/……x?……/時,引擎必須是否嘗試匹配X。對于/……X+……/的情況,毫無疑問,X至少嘗試匹配一次——因為加號要求必須匹配至少一次。第一個X匹配之后,此要求已經滿足,需要決定是否嘗試下一個X。如果決定進行,還要決定是否匹配第三個X,第四個X,如此繼續。每次選擇,其實就是做一個標記,用于提示此處還有另一個可能的選擇,保留起來以備用。在回溯的過程中要考慮兩個要點:哪個分支應當首先選擇?回溯的時候使用的是哪個(或者是哪些個)之前保存的分支?

    第一個問題是按下面這條重要原則來選擇的:

        如果需要在“進行嘗試”和“路過嘗試”之間選擇,對于匹配優先量詞,引擎會優先選擇“進行嘗試”,而對于忽略優先量詞,會選擇“路過嘗試”。

    第二個問題是按以下這條原則:

        距離當前最近儲存的選項就是當本地失敗強制回溯時返回的。使用的原則是LIFO(last in first out,后進先出)。

    我們先來看幾個在道路中做標記的例子:

        1、未進行回溯的匹配

            用[ab?c]來匹配“abc”。[a]匹配之后,匹配的當前狀態如下:

“abc” ab?c

            現在輪到[b?]了,正則引擎需要決定:是需要嘗試[b]呢,還是跳過?因為[?]是匹配優先的,它會嘗試匹配。但是,為了確保在這個嘗試最終失敗之后能夠恢復,引擎會把:

“abc” ab?c
            添加到備用狀態序列中。也就是說,稍后引擎可能從下面的位置繼續匹配:從正則表達式中的[b?]之后,字符串的c之前(也就是說當前的位置)匹配。這實際上就是跳過[b]的匹配,而問題容許這樣做。引擎做好標記后,就會繼續向前檢查[b]。在示例中,它能夠匹配,所以新的當前狀態變為:
“abc” ab?c

            最終的[c]也能成功匹配,所以整個匹配完成。備用狀態不再需要了,所以不再保存它們。

        2、進行了回溯的匹配

            下面要匹配的文本是“ac”,在嘗試[b]之前,一切都與之前的過程相同。顯然,這次[b]無法匹配。也就是說,對[……?]進行嘗試的路走不通了。因為有一個備用狀態,這個“局部匹配失敗”產工會導致整體匹配失敗。引擎會進行回溯,也就是說,把“當前狀態”切換為最近保存的狀態。

“ac” ab?c

            在[b]嘗試之前保存的尚未嘗試的選項。這時候,[c]可以匹配c,所以整個匹配宣告完成。

        3、不成功的匹配

            現在要匹配的文本是“abx”。在嘗試[b]以前,因為存在問號,保存了這個備用狀態:

“abx” ab?c

            [b]能夠匹配,但這條路往下卻走不通了,因為[c]無法匹配x。于是引擎會回溯到之前的狀態,“交還”b給[c]來匹配。顯然,這次測試也失敗了。如果還有其他保存的狀態,回溯會繼續進行,但是此時不存在其他狀態,在字符串中當前位置開始的整個匹配也就宣告失敗。

    目前對正則表達式的回溯只能理解這么多,以后我再慢慢補充吧!

您可能感興趣的文章:
  • PHP 正則表達式效率 貪婪、非貪婪與回溯分析(推薦)
  • 正則中的回溯定義與用法分析【JS與java實現】
  • 編寫高質量的js之正確理解正則表達式回溯
  • 深度分析正則(pcre)最大回溯/遞歸限制
  • 小議正則表達式效率 貪婪、非貪婪與回溯
  • PHP正則表達式的效率 回溯與固化分組
  • AS3 js正則表達式 反向引用(backreference)
  • 詳解JavaScript正則表達式之分組匹配及反向引用
  • php正則表達式的模式修正符和逆向引用使用介紹
  • PHP正則表達式的逆向引用與子模式分析
  • JavaScript正則表達式之后向引用實例代碼
  • VBS教程:正則表達式簡介 -后向引用
  • 正則表達式學習教程之回溯引用backreference詳解

標簽:無錫 長沙 綿陽 西安 銅川 宣城 泰州 重慶

巨人網絡通訊聲明:本文標題《正則表達式之回溯》,本文關鍵詞  正則,表達式,之,回溯,正則,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《正則表達式之回溯》相關的同類信息!
  • 本頁收集關于正則表達式之回溯的相關信息資訊供網民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    扒开伸进免费视频| 日韩免费在线观看| 中文字幕制服丝袜成人av| 国产一区二区免费视频| 黄免费在线观看| 欧美精品一区二区蜜臀亚洲| 蜜臀av性久久久久蜜臀aⅴ四虎| 少妇一级淫片免费放播放| 欧美精品tushy高清| 亚洲成人在线观看视频| 在线观看免费视频黄| 在线综合视频播放| 日韩电影免费在线看| 少妇大叫太粗太大爽一区二区| 日韩欧美区一区二| 久久精品99国产精品| 99精品欧美一区二区| 国产肉丝袜一区二区| 国产成人午夜99999| 欧美做爰爽爽爽爽爽爽| 亚洲欧美另类久久久精品2019| 91色在线porny| 欧美精品一级二级| 奇米影视一区二区三区小说| 四虎永久免费在线观看| 国产视频一区二区在线观看| 成人性生交大片免费| 在线观看亚洲专区| 午夜精品一区二区三区电影天堂| 亚洲图片综合网| 精品国产一区二区三区四区四| 激情图区综合网| 欧美肥妇bbwbbw| 亚洲欧美视频在线观看视频| 国产国语老龄妇女a片| 欧美大胆人体bbbb| 国产精品一区久久久久| 色综合久久久久综合体桃花网| 一区二区三区国产精品| 久久久久9999| 久久人人爽人人爽| fc2成人免费人成在线观看播放 | 真人bbbbbbbbb毛片| 欧美成人三级电影在线| 国产福利一区在线| 欧洲精品在线观看| 日韩高清国产一区在线| 天美传媒免费在线观看| 一区二区三区中文字幕| 色呦呦一区二区| 久久精品欧美一区二区三区不卡| 91在线国产观看| 日韩一级大片在线观看| 国产二区国产一区在线观看| 日本韩国欧美在线| 蜜桃av一区二区| 中文字幕av播放| 午夜婷婷国产麻豆精品| 男人的天堂官网| 亚洲少妇30p| 久久精品国产亚洲av久| 日韩一区中文字幕| 97香蕉碰碰人妻国产欧美| 日本一二三四高清不卡| 亚洲精品久久一区二区三区777 | 精品国产免费一区二区三区四区| 成人性生交大片免费看视频在线| 69p69国产精品| 国产99久久精品| 日韩一区二区免费视频| 成人美女视频在线观看18| 日韩一区二区电影网| 成人蜜臀av电影| 精品久久久久久无| 91丨porny丨蝌蚪视频| 久久综合色之久久综合| 亚洲综合中文网| 日本一区二区免费在线观看视频| 国产午夜在线一区二区三区| 中文字幕欧美日本乱码一线二线| 又黄又爽的网站| 中文字幕亚洲一区二区av在线| www.久久av| 亚洲一区二区四区蜜桃| 激情无码人妻又粗又大| 日韩国产精品久久久久久亚洲| 日本黄色小说视频| 久99久精品视频免费观看| 欧美人成免费网站| 成人免费毛片aaaaa**| 精品国产欧美一区二区| 久草免费资源站| 1024成人网| 日本女人性生活视频| 美国毛片一区二区| 69精品人人人人| 久久aaaa片一区二区| 中文幕一区二区三区久久蜜桃| 免费成人深夜夜行p站| 亚洲最大色网站| 中文字幕av免费在线观看| 国产综合色在线视频区| 欧美一级艳片视频免费观看| 免费高清视频在线观看| 最新国产成人在线观看| 色哟哟一一国产精品| 韩国精品在线观看| 日韩精品一区国产麻豆| 中国极品少妇xxxx| 一区二区三区精品| 91久久精品一区二区三区| 国产成人8x视频一区二区| 久久综合九色欧美综合狠狠| 老鸭窝一区二区| 日韩国产在线一| 欧美一二三四在线| 免费看毛片的网站| 亚洲成人在线免费| 欧美日韩国产天堂| 台湾佬美性中文| 亚洲资源在线观看| 欧美色视频在线观看| 69久久精品无码一区二区| 亚洲天堂免费看| 91久久精品网| 91欧美一区二区| 一区二区国产视频| 欧美午夜电影网| 91porn在线| 亚洲成a人v欧美综合天堂下载| 欧美片在线播放| 亚洲男女在线观看| 日本不卡一二三| 亚洲精品一区在线观看| 亚洲一区二区自偷自拍| 国内外成人在线视频| 久久免费国产精品| 国产又色又爽又高潮免费| 国产成人午夜电影网| |精品福利一区二区三区| 日本乱人伦一区| 精品人妻人人做人人爽夜夜爽| 亚洲制服丝袜av| 91精品国产色综合久久不卡电影 | 琪琪久久久久日韩精品| 精品免费国产二区三区| 久久中文字幕精品| 国产a级毛片一区| 亚洲欧美日韩精品久久久久| 91成人在线免费观看| 成人欧美精品一区二区| 日韩 欧美一区二区三区| 精品国产免费视频| 国产免费久久久久| 在线观看你懂的视频| 日韩中文字幕1| 久久这里只有精品首页| 欧美自拍偷拍网| av一区二区三区黑人| 亚洲国产婷婷综合在线精品| 日韩一级在线观看| 欧美a在线播放| 99久久精品国产网站| 婷婷一区二区三区| 久久久99久久| 在线免费观看视频一区| 你懂得在线视频| 国产福利一区二区三区| 一区二区欧美精品| 欧美成人艳星乳罩| 老女人性淫交视频| 亚洲天堂美女视频| 国产美女视频91| 一区二区三区免费在线观看| 日韩精品一区二区三区视频在线观看| 亚洲图片第一页| 爱情岛论坛亚洲自拍| 久久av中文字幕片| 亚洲视频综合在线| 欧美大片在线观看一区| 人妻少妇精品一区二区三区| 久久人人爽人人人人片| 成人午夜视频免费看| 爽好久久久欧美精品| 国产免费成人在线视频| 欧美日韩不卡一区二区| 日本理论中文字幕| 四虎成人免费视频| 国产精品综合二区| 亚洲国产欧美在线| 亚洲国产成人一区二区三区| 制服丝袜日韩国产| 91久久国产综合| www.自拍偷拍| 91免费看视频| 国产在线精品一区二区| 亚洲成人一二三| 国产精品久久久久久久蜜臀| 日韩欧美自拍偷拍| 在线观看不卡视频|