校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > PHP 正則表達式效率 貪婪、非貪婪與回溯分析(推薦)

PHP 正則表達式效率 貪婪、非貪婪與回溯分析(推薦)

熱門標簽:西藏智能外呼系統代理商 梅縣地圖標注 貴港公司如何申請400電話 呼叫系統外呼只能兩次 400電話辦理電話辦理 地圖標注教學點 甘肅醫療外呼系統排名 ai電話機器人搭建 外呼系統無呼出路由是什么原因

先掃盲一下什么是正則表達式的貪婪,什么是非貪婪?或者說什么是匹配優先量詞,什么是忽略優先量詞?

好吧,我也不知道概念是什么,來舉個例子吧。

某同學想過濾之間的內容,那是這么寫正則以及程序的。

$str = preg_replace('%script>.+?/script>%i','',$str);//非貪婪 

看起來,好像沒什么問題,其實則不然。若

$str = 'scriptscript>alert(document.cookie)/script>>alert(document.cookie)/script>'; 

那么經過上面的程序處理,其結果為

$str = 'scriptscript>alert(document.cookie)/script>>alert(document.cookie)/script>'; 
$str = preg_replace('%script>.+?/script>%i','',$str);//非貪婪 
print_r($str); 
//$str 輸出為 script>alert(document.cookie)/script> 

仍然達不到他想要的效果。上面的就是非貪婪,也有的叫惰性。其標志非貪婪的標識為量數元字符后面加? ,比如 +?、*?、??(比較特殊,以后的BLOG中,我會寫到)等。即標識非貪婪,如果不寫?就是貪婪。比如

$str = 'scriptscript>alert(document.cookie)/script>>alert(document.cookie)/script>'; 
$str = preg_replace('%script>.+/script>%i','',$str);//非貪婪 
print_r($str); 
//$str 輸出為 script 只有這些了,好像還是不太合適,哈,您知道如何重寫那個正則嗎?

以上為貪婪,非貪婪的區別介紹。下面,聊下貪婪、非貪婪引起的回溯問題。先看個小例子。

正則表達式為\w*(\d+),字符串為cfc456n,那么,這個正則匹配的$1是多少??

如果您回答是 456,那么,恭喜你,回答錯了,其結果不是456,而是6,您知道為什么嗎?

CFC4N來解釋一下,當正則引擎用正則\w*(\d+)去匹配字符串cfc456n時,會先用\w*去匹配字符串cfc456n,首先,\w*會匹配字符串cfc456n的所有字符,然后再交給\d+去匹配剩下的字符串,而剩下的沒了,這時,\w*規則會不情愿的吐出一個字符,給\d+去匹配,同時,在吐出字符之前,記錄一個點,這個點,就是用于回溯的點,然后\d+去匹配n,發現并不能匹配成功,會再次要求\w*再吐出一個字符,\w*會先再次記錄一個回溯的點,再吐出一個字符。這時,\w* 匹配的結果只有cfc45了,已經吐出6n了,\d+再去匹配6,發現匹配成功,則會通知引擎,匹配成功了,就直接顯示出來了。所以,(\d+)的結果是6,而不是456。

當上面的正則表達式改為 \w*?(\d+)(注意,此處為非貪婪),字符串仍然為cfc456n,那么,這時候,正則匹配的$1是多少??

甲同學回答:結果是 456。

嗯,是的,正確,是456,CFC4N弱弱的問下,為什么是456 呢?

我在來解釋一下 為什么是456

正則表達式有條規則,是量詞優先匹配,所以\w*?會先去匹配字符串cfc456,由于\w*?是非貪婪,正則引擎會用表達式\w+?每次僅匹配一個字符串,然后再將控制權交給后面的\d+去匹配下一個字符,同時,記錄一個點,用于在匹配不成功的時候,返回這里,再次匹配,也就是回溯點。由于\w后面是量詞是*,*表示0到無數次,所以,首先是0次,也就是\w*?匹配個空,記錄回溯點,將控制權交給\d+,\d+去匹配cfc456n的第一個字符c,然后,匹配失敗,于是乎,接著講控制權交給\w*?去匹配cfc456n的c,\w*?匹配c成功,由于是非貪婪,所以,他每次只匹配一個字符,記錄回溯點,然后再將控制權交給\d+匹配f,接著,\d+匹配f再失敗,再把控制權給\w*?,\w*?再匹配c,記錄回溯點(這時\w*?匹配結果是cfc了),再把控制權給\d+,\d+去匹配4,匹配成功,然后,由于量詞是+,就是1到無數次,所以,接著往后匹配,再匹配5,成功,再接著,再匹配6,成功,再接著,繼續匹配操作,下一個字符是n,匹配失敗,這時,\d+會吧控制權交出去。由于\d+后面已經沒有正則表達式了,所以,整個正則表達式宣告匹配完成,其結果就是 cfc456, 其中第一組結果是456。親愛的同學,您明白剛剛的題目的結果,為什么是456了嗎?

好了,您是否從上面的例子了解了貪婪,非貪婪的匹配原理了?那您是否明白您在什么時候需要使用貪婪,非貪婪去處理您的字符串了?

鳥哥的文章里講到針對表達式、程序為

$reg = "/script>.*?\/script>/is"; 
$str = "script>********/script>"; //長度大于100014 
$ret = preg_repalce($reg, "", $str); //返回NULL 

其原因就是回溯太多了,直到造成耗盡??臻g爆棧。

再來看個例子。

字符串

$str = 'script>123456/script>'; 

正則表達式為

$strRegex1 = '%script>.+\/script>%'; 
$strRegex2 = '%script>.+?\/script>%'; 
$strRegex3 = '%script>(?:(?!\/script>).)+\/script>%'; 

以上所述是小編給大家介紹的PHP 正則表達式效率 貪婪、非貪婪與回溯分析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

您可能感興趣的文章:
  • PHP實現的回溯算法示例
  • PHP正則表達式的效率 回溯與固化分組
  • PHP回溯法解決0-1背包問題實例分析
  • PHP實現基于回溯法求解迷宮問題的方法詳解
  • php實現猴子選大王問題算法實例
  • PHP貪婪算法解決0-1背包問題實例分析
  • php約瑟夫問題解決關于處死犯人的算法
  • PHP使用棧解決約瑟夫環問題算法示例
  • PHP基于回溯算法解決n皇后問題的方法示例

標簽:湖州 涼山 哈密 本溪 泰安 大興安嶺 常州

巨人網絡通訊聲明:本文標題《PHP 正則表達式效率 貪婪、非貪婪與回溯分析(推薦)》,本文關鍵詞  PHP,正則,表達式,效率,貪婪,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《PHP 正則表達式效率 貪婪、非貪婪與回溯分析(推薦)》相關的同類信息!
  • 本頁收集關于PHP 正則表達式效率 貪婪、非貪婪與回溯分析(推薦)的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    99国产精品99久久久久久| 日韩一区二区免费在线观看| eeuss鲁一区二区三区| 色美美综合视频| 日韩欧美一区二区免费| 蜜桃一区二区三区在线观看| 欧美精品免费视频| 久久99久久99小草精品免视看| 成人av电影在线观看| 日韩无一区二区| 亚洲激情图片qvod| 欧美日韩在线精品一区二区三区激情| 久久精品夜色噜噜亚洲aⅴ| 国产精品一区免费视频| 国产精品成人免费精品自在线观看| 秋霞午夜鲁丝一区二区老狼| 日韩欧美亚洲国产精品字幕久久久| 亚洲精品免费播放| 欧美理论在线播放| 亚洲精品写真福利| 成人激情动漫在线观看| 亚洲美女电影在线| 日韩一区二区三区视频在线| 亚洲图片自拍偷拍| 欧美成人国产一区二区| jiyouzz国产精品久久| 调教+趴+乳夹+国产+精品| 欧美精品一区视频| 色妹子一区二区| 久久99国内精品| 欧美军同video69gay| 久久国产免费看| 亚洲视频免费在线| 精品少妇一区二区三区免费观看 | 99在线精品一区二区三区| 一区二区三区四区视频精品免费 | 蜜臀精品久久久久久蜜臀| 欧美亚洲一区二区在线观看| 亚洲欧洲精品天堂一级| 成人午夜大片免费观看| 亚洲一区二区在线免费看| 色综合天天视频在线观看| 亚洲天堂av老司机| 在线免费观看日本一区| 亚洲欧美日韩在线| 精品久久久久av影院| 色综合一区二区三区| 狠狠色伊人亚洲综合成人| 久久精品亚洲精品国产欧美kt∨| 激情丁香综合五月| 亚洲一区二区在线免费观看视频| 欧美曰成人黄网| 国产传媒久久文化传媒| 日韩精品电影在线观看| 日韩一区在线播放| 国产亚洲欧美色| 91麻豆蜜桃一区二区三区| 一区二区三区中文免费| 国产欧美精品一区| 精品国产成人系列| 91精品国产全国免费观看| 狠狠色丁香久久婷婷综合_中| 久久九九全国免费| 日韩美女视频一区二区在线观看| 国产福利精品一区二区| 亚洲精品视频免费观看| 国产精品每日更新| 国产无一区二区| www欧美成人18+| 色综合久久99| 日本亚洲免费观看| 天堂资源在线中文精品| 亚洲乱码国产乱码精品精可以看 | 欧美一卡2卡3卡4卡| 欧美日精品一区视频| 色综合久久久久| 91福利视频久久久久| 91黄色小视频| 欧美性高清videossexo| 欧美视频完全免费看| 欧美在线免费观看亚洲| 在线观看精品一区| 欧美性生活影院| 国产毛片精品视频| 国产一区亚洲一区| 国产精品羞羞答答xxdd| 亚洲成人综合在线| 午夜精品久久久久久久久久| 久久久久97国产精华液好用吗| 成人午夜免费视频| 午夜精品爽啪视频| 青青草国产精品97视觉盛宴 | 在线91免费看| 成人av资源在线| 伦理电影国产精品| 国产精品正在播放| 日本成人中文字幕在线视频| 免费av网站大全久久| 国产一区二区三区综合| 亚洲在线观看免费视频| 欧美国产精品一区二区三区| 国产人久久人人人人爽| 日韩伦理电影网| 国产欧美日产一区| 夜夜精品浪潮av一区二区三区| 夜夜精品浪潮av一区二区三区| 日韩高清电影一区| 国产精品系列在线观看| 99久久久久久| 欧美日韩久久久一区| 波波电影院一区二区三区| 在线观看欧美黄色| 日韩一级欧美一级| 欧美精品一卡两卡| 在线看日本不卡| 91理论电影在线观看| 欧美精品在线观看一区二区| 国产午夜精品一区二区| 亚洲影院在线观看| 亚洲私人影院在线观看| 亚洲综合丁香婷婷六月香| 日韩一区中文字幕| 欧美体内she精视频| 欧美一区二区三区日韩| 欧美激情综合五月色丁香小说| 一区二区三区丝袜| 亚洲男人的天堂网| 蜜桃精品在线观看| 精品一区二区久久久| 国产又黄又大久久| 国产一区二区三区久久久| 成人av资源站| 久久综合给合久久狠狠狠97色69| 日韩毛片在线免费观看| 国产一区二区在线观看免费| 欧美亚洲一区三区| 中文字幕制服丝袜一区二区三区| 视频在线观看国产精品| 石原莉奈一区二区三区在线观看| 国产美女久久久久| 91精品国产综合久久蜜臀| 7777精品伊人久久久大香线蕉最新版| 久久综合精品国产一区二区三区| 一区二区激情视频| 国产精品一区二区在线观看网站 | 在线观看欧美黄色| 国产精品久久一级| 国产精品你懂的| 亚洲视频 欧洲视频| 黄一区二区三区| 欧美日韩精品免费观看视频| 中文字幕亚洲视频| 极品美女销魂一区二区三区| 欧美狂野另类xxxxoooo| 一区二区三区四区视频精品免费| 亚洲成人午夜影院| 日本韩国欧美国产| 综合在线观看色| 天天做天天摸天天爽国产一区| 成人午夜激情视频| 欧美日韩精品一区二区天天拍小说| 亚洲欧洲日韩在线| 色综合天天天天做夜夜夜夜做| 国产精品女主播av| 丁香天五香天堂综合| 99久久精品免费精品国产| 欧洲一区在线观看| 亚洲男人的天堂在线aⅴ视频| 免费人成在线不卡| 337p亚洲精品色噜噜噜| 午夜欧美视频在线观看| 丁香亚洲综合激情啪啪综合| 欧美日韩一区二区三区四区| 夜夜爽夜夜爽精品视频| 在线看国产一区二区| 国产丝袜欧美中文另类| 国产成人在线视频网址| 国产亚洲欧洲一区高清在线观看| 国产麻豆91精品| 欧美日韩一区不卡| 婷婷国产v国产偷v亚洲高清| 日韩精品在线一区| 国产乱子伦视频一区二区三区 | 免费成人结看片| 欧美一区二区在线免费观看| 欧美经典一区二区| 99re热视频这里只精品| 精品久久久三级丝袜| 国产精品18久久久久久久久| 欧美日韩国产综合视频在线观看| 午夜av一区二区三区| 日韩精品一区二区三区在线播放| 国产麻豆视频一区| 亚洲人成在线观看一区二区| 欧美午夜精品久久久久久超碰| 国产欧美精品区一区二区三区| 成人免费视频免费观看| 亚洲精品免费电影| 日韩视频在线观看一区二区| 亚洲国产成人高清精品|