亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 語言 > PHP > 正文

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

2024-09-04 11:47:39
字體:
來源:轉載
供稿:網友

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

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

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

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

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

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

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

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

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

  1. $str='<script<script>alert(document.cookie)</script>>alert(document.cookie)</script>'
  2. $str= preg_replace('%<script>.+</script>%i','',$str);//非貪婪 
  3. print_r($str); 
  4. //$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了嗎?

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

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

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

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

再來看個例子。

字符串:$str='<script>123456</script>';

正則表達式為:

  1. $strRegex1='%<script>.+<//script>%'
  2. $strRegex2='%<script>.+?<//script>%'
  3. $strRegex3='%<script>(?:(?!<//script>).)+<//script>%'

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品欧美日韩一区二区| 欧美一区二区三区免费视| 国产精品视频久久久| 7m第一福利500精品视频| 主播福利视频一区| 国产亚洲欧美日韩美女| 亚洲国产精品一区二区久| 成人网在线观看| 91中文在线视频| 欧美巨乳在线观看| 91免费精品国偷自产在线| 国产亚洲免费的视频看| 97久久精品人搡人人玩| 欧美最猛性xxxxx亚洲精品| 欧美第一黄色网| 欧美黑人巨大精品一区二区| 2020国产精品视频| 国产精品一区二区女厕厕| 欧美激情免费在线| 久久久久久久久中文字幕| 综合欧美国产视频二区| 亚洲综合最新在线| 亚洲影视中文字幕| 美日韩精品免费观看视频| 庆余年2免费日韩剧观看大牛| 亚洲国产成人久久综合| 亚洲国产精品大全| 日韩免费中文字幕| 午夜精品福利电影| 欧美成人精品在线观看| 欧美成人三级视频网站| 欧美麻豆久久久久久中文| 538国产精品一区二区免费视频| 国产精品尤物福利片在线观看| 96精品视频在线| 欧美乱大交做爰xxxⅹ性3| 国产精品美腿一区在线看| 日本成人精品在线| 欧美重口另类videos人妖| 久久综合色88| 国产精品免费观看在线| 78色国产精品| 欧美综合在线第二页| 久久亚洲精品中文字幕冲田杏梨| 亚洲一区二区三区sesese| 亚洲电影免费观看| 日本不卡视频在线播放| 欧洲永久精品大片ww免费漫画| 日韩乱码在线视频| 69久久夜色精品国产69| 5252色成人免费视频| www.久久久久久.com| 草民午夜欧美限制a级福利片| 操91在线视频| 黑人巨大精品欧美一区二区免费| 日韩av最新在线观看| 日韩成人网免费视频| 国模私拍一区二区三区| 日韩精品中文字幕在线| 日本精品中文字幕| 久久精品99久久久香蕉| 国产精品一香蕉国产线看观看| 97人人模人人爽人人喊中文字| 美女国内精品自产拍在线播放| 亚洲黄色www网站| 国产精选久久久久久| 欧美日韩第一页| 日韩黄在线观看| 97视频在线看| 亚洲xxxx做受欧美| 国产精品亚洲自拍| 国产精品永久免费| 亚洲精品中文字幕有码专区| 欧美性猛交xxxx富婆| 成人久久18免费网站图片| 亚洲性av网站| 欧美极品少妇xxxxⅹ免费视频| 日本国产欧美一区二区三区| 日韩av不卡电影| 亚洲偷欧美偷国内偷| 亚洲尤物视频网| 欧美另类精品xxxx孕妇| 欧美性色xo影院| 精品女同一区二区三区在线播放| 久久伊人免费视频| 日韩美女在线播放| 午夜精品久久久久久99热软件| 欧美精品免费播放| 亚洲韩国欧洲国产日产av| 日韩欧中文字幕| 亚洲欧美成人精品| 亚洲精品免费网站| 日韩av毛片网| 大量国产精品视频| 中文字幕亚洲综合| 成人久久久久久久| 在线播放国产一区中文字幕剧情欧美| 精品久久久久久久久久久| 久久久久成人网| 92国产精品久久久久首页| 国产视频精品va久久久久久| 国产成人精品久久二区二区91| 在线日韩日本国产亚洲| 97视频在线观看免费高清完整版在线观看| 97国产成人精品视频| 久久97久久97精品免视看| 日韩精品极品毛片系列视频| 日韩中文字幕在线精品| 国产精自产拍久久久久久蜜| 一区二区国产精品视频| 欧美黑人xxxⅹ高潮交| 亚洲精品国精品久久99热一| 性色av一区二区三区免费| 国产精品视频播放| 91免费在线视频| 亚洲精品国产精品国自产观看浪潮| 97涩涩爰在线观看亚洲| 欧美夜福利tv在线| 57pao精品| 欧美www在线| www.日本久久久久com.| 日本不卡视频在线播放| 一区二区三区视频在线| 久久精品国产一区二区电影| 久久成年人免费电影| 俺也去精品视频在线观看| 久久精品电影网| 中文字幕日韩欧美在线| 久久精品99国产精品酒店日本| 亚洲国产精品va在线看黑人动漫| 国产成人自拍视频在线观看| 国产欧美精品日韩| 成人黄色网免费| 欧美黑人一区二区三区| 中文字幕亚洲专区| 欧美香蕉大胸在线视频观看| 亚洲午夜精品久久久久久性色| 亚洲成人在线网| 久久理论片午夜琪琪电影网| 永久免费毛片在线播放不卡| 91精品视频免费观看| 亚洲精品电影在线| 久久久久久九九九| 中文字幕av一区二区| 在线日韩中文字幕| 午夜精品99久久免费| 国产一区二区日韩精品欧美精品| 色妞在线综合亚洲欧美| 色爱精品视频一区| 亚洲美女性生活视频| 国产偷国产偷亚洲清高网站| 亚洲乱码国产乱码精品精天堂| 国产亚洲精品美女久久久久| 国产成人精品免费久久久久| 日韩在线视频观看| 欧美老女人在线视频| 久久久噜噜噜久久中文字免| 亚洲欧美在线x视频| 亚洲第一区在线| 亚洲色图第一页| 欧美色视频日本高清在线观看| 欧美孕妇与黑人孕交| 久久99精品视频一区97| 亚洲毛片在线免费观看|