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

首頁 > 編程 > regex > 正文

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

2020-01-20 22:03:20
字體:
來源:轉載
供稿:網友

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

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

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

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

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

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

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

$str = '<script<script>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 = '<script<script>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 正則表達式效率 貪婪、非貪婪與回溯分析,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
神马久久久久久| 欧美在线免费视频| 91黑丝高跟在线| 成人网址在线观看| 一本大道亚洲视频| 中文精品99久久国产香蕉| 疯狂做受xxxx欧美肥白少妇| 久久久精品中文字幕| 亚洲欧美国产精品久久久久久久| 欧美巨猛xxxx猛交黑人97人| 亚洲国产91色在线| 成人精品在线视频| 国产日韩av在线播放| 亚洲精品国产品国语在线| 中文字幕久久久av一区| 精品爽片免费看久久| 国产日产欧美精品| 亚洲一区www| 日韩在线观看免费全| 狠狠爱在线视频一区| 日本国产一区二区三区| 日韩女优在线播放| 欧洲亚洲免费视频| 亚洲成人久久网| 久久综合伊人77777蜜臀| 中文字幕日韩在线播放| 亚洲综合在线做性| 91精品一区二区| 成人妇女淫片aaaa视频| 国产精品中文久久久久久久| 丝袜亚洲另类欧美重口| 国语自产精品视频在线看一大j8| 国产亚洲成av人片在线观看桃| 国内精品模特av私拍在线观看| 91在线看www| 国产精品久久久久免费a∨大胸| www.午夜精品| 91高清视频免费观看| 亚洲japanese制服美女| 国产国产精品人在线视| 国产精品久久久久av| 92裸体在线视频网站| 中文字幕av一区中文字幕天堂| 久久久精品视频在线观看| 欧美日韩一区二区在线| 亚洲免费视频一区二区| 91视频88av| 中文字幕亚洲欧美日韩2019| 亚洲国产女人aaa毛片在线| 欧美老女人在线视频| 欧美性生交大片免费| 川上优av一区二区线观看| 国产精品igao视频| 亚洲免费高清视频| 日本在线观看天堂男亚洲| 一区二区三区国产视频| 国产视频久久久久| 日产日韩在线亚洲欧美| 91精品国产高清久久久久久久久| 成人日韩av在线| 一区二区三区视频观看| 久久久久久久久久久网站| 日本在线精品视频| 中文字幕不卡在线视频极品| 色爱精品视频一区| 欧日韩在线观看| 欧美巨乳美女视频| 亚洲精品www久久久| 在线播放精品一区二区三区| 91在线|亚洲| 亚洲精品视频在线播放| 久久精品国产电影| 亚洲理论在线a中文字幕| 精品中文字幕久久久久久| 国产成人亚洲综合91精品| 午夜精品一区二区三区在线播放| 色无极影院亚洲| 国产欧美日韩免费| 国产精品自拍偷拍| 欧美在线视频网| 国产精品直播网红| 精品精品国产国产自在线| 视频在线观看99| 国产精品视频自在线| 国产999精品| 国产亚洲一区二区精品| 日本欧美一二三区| 成人观看高清在线观看免费| 国产成人精品网站| 亚洲电影成人av99爱色| 欧美性极品xxxx做受| 91精品国产综合久久香蕉922| 国产日产欧美精品| 亚洲精品国精品久久99热| 欧美另类69精品久久久久9999| 国产成人高潮免费观看精品| 亚洲欧洲在线免费| 欧美激情日韩图片| 成人在线精品视频| 日韩欧美亚洲范冰冰与中字| 日本精品在线视频| 91成人福利在线| 97精品伊人久久久大香线蕉| 欧美性视频网站| 国产精品夜间视频香蕉| 国产一区二区三区直播精品电影| 成人久久精品视频| 国产精品女主播视频| 欧美专区国产专区| 国产精品av在线播放| 亚洲一区制服诱惑| 国产亚洲精品久久久久动| 91精品国产色综合久久不卡98口| 亚洲精品乱码久久久久久金桔影视| 日韩电影免费观看在线| 日本19禁啪啪免费观看www| 91久久久久久| 一区二区三区 在线观看视| 亚洲高清色综合| 亚洲精品久久久久久久久久久| 欧美激情成人在线视频| 日本精品va在线观看| 亚洲国产天堂久久综合网| 日韩精品在线观看一区二区| 欧美久久久精品| 亚洲精品国产精品久久清纯直播| 国产精品久久久久久久久影视| 日韩高清电影免费观看完整| 性欧美xxxx| 操日韩av在线电影| 国产婷婷97碰碰久久人人蜜臀| 国产一区二区成人| 国产精品福利在线| 国产精品爽爽ⅴa在线观看| 亚洲精品国产精品乱码不99按摩| 一区二区三区国产视频| 国产综合在线视频| 日韩av电影在线网| 欧美一区二区大胆人体摄影专业网站| 在线不卡国产精品| 精品国模在线视频| 国产精品video| 中文字幕日韩电影| 亚洲性夜色噜噜噜7777| 久久久久久综合网天天| 91成品人片a无限观看| 日韩av在线精品| 一区二区成人av| 日本伊人精品一区二区三区介绍| 亚洲欧美激情四射在线日| 黄色91在线观看| 亚洲一级一级97网| 国产91在线播放精品91| 亚洲欧美福利视频| 亚洲第五色综合网| 亚洲国产日韩欧美在线图片| 亚洲午夜国产成人av电影男同| 久久69精品久久久久久国产越南| 国产亚洲视频在线| 亚洲天堂av网| 国产成人福利视频| 亚洲欧美激情视频| 日韩在线观看免费高清完整版| 精品视频久久久久久久|