婷婷综合国产,91蜜桃婷婷狠狠久久综合9色 ,九九九九九精品,国产综合av

主頁(yè) > 知識(shí)庫(kù) > 正則表達(dá)式性能優(yōu)化方法(高效正則表達(dá)式書(shū)寫(xiě))

正則表達(dá)式性能優(yōu)化方法(高效正則表達(dá)式書(shū)寫(xiě))

熱門(mén)標(biāo)簽:400免費(fèi)電話(huà)去哪申請(qǐng) css百度地圖標(biāo)注位置顯示 宿遷智能外呼系統(tǒng)供應(yīng)商 地圖標(biāo)注商戶(hù)中心要收錢(qián)多少 菏澤智能ai電銷(xiāo)機(jī)器人銷(xiāo)售公司 鄂州人工智能電銷(xiāo)機(jī)器人軟件 線(xiàn)上教育ai外呼系統(tǒng) 實(shí)用地圖標(biāo)注app 地圖標(biāo)注字母的軟件

這里說(shuō)的正則表達(dá)式優(yōu)化,主要是針對(duì)目前常用的NFA模式正則表達(dá)式,詳細(xì)可以參考:正則表達(dá)式匹配解析過(guò)程探討分析(正則表達(dá)式匹配原理)。從上面例子,我們可以推斷出,影響NFA類(lèi)正則表達(dá)式(常見(jiàn)語(yǔ)言:GNU Emacs,Java,ergp,less,more,.NET語(yǔ)言,
PCRE library,Perl,PHP,Python,Ruby,sed,vi )其實(shí)主要是它的“回溯”,減少“回溯”次數(shù)(減少循環(huán)查找同一個(gè)字符次數(shù)),是提高性能的主要方法。 我們來(lái)看個(gè)例子:

源字符串:script type="text/javascript">adsfadfsdasfsdafdsfsadfsa/script>

匹配要求,匹配script….>…./script>標(biāo)簽里面所有內(nèi)容,包括改標(biāo)簽

常見(jiàn)寫(xiě)法(1),因?yàn)閟cript后面可能出現(xiàn)字符、空白、特殊符號(hào)等,還有標(biāo)簽里面也可能出現(xiàn)各種js代碼。我們簡(jiǎn)單方法是:

正則表達(dá)式:script.*?>.*?/script> (測(cè)試工具使用了:regexBuddy)

總共花費(fèi)115步,回溯了:48次。 因?yàn)槲覀兪褂谩?”字符,匹配默認(rèn)情況下除了\n之外所有字符。
方法(2),我們分析特點(diǎn)發(fā)現(xiàn),script…>后面,應(yīng)該是除了”>”之外都可以字符,然后一對(duì)script>標(biāo)簽里面js內(nèi)容。可以定義為除了””之外。(這里面我只是舉例說(shuō)明優(yōu)化方法,實(shí)際網(wǎng)頁(yè)中script標(biāo)簽里面,常見(jiàn)都會(huì)出現(xiàn)有””字符了)

正則表達(dá)式:script[^?>]+>[^]+/script>

19步,0次回溯! ,步驟只有原先的15%左右,性能幾倍的提升了!
從上面我們看到,不同正則表達(dá)式,對(duì)通用字符配平,性能相差會(huì)很大。減少“回溯”是最好的方法,減少回溯其中最主要的方法是:”用最小范圍的元字符,盡量避免用過(guò)大的元字符!”。一般規(guī)律如下:

1、使用正確的邊界匹配器(^、$、\b、\B等),限定搜索字符串位置
2、使用具體的元字符、字符類(lèi)(\d、\w、\s等) ,少用”.”字符
3、使用正確的量詞(+、*、?、{n,m}),如果能夠限定長(zhǎng)度,匹配最佳
4、使用非捕獲組、原子組,減少?zèng)]有必要的字匹配捕獲用(?:)

如:我想匹配一些英文字母,它后面接的是數(shù)字。如:abc1234,我可以寫(xiě) “\w+\d+”,也可以寫(xiě)”[a-zA-Z]+\d+” ,其中第一個(gè)\w+會(huì)先匹配所有abc1234,然后回溯,匹配滿(mǎn)足\d+格式。一共4步,而后面這個(gè)只需要2步,步驟減少一半了!好了,今天就先到這里,歡迎大家討論、交流!

您可能感興趣的文章:
  • Python 正則表達(dá)式匹配字符串中的http鏈接方法
  • python正則表達(dá)式去除兩個(gè)特殊字符間的內(nèi)容方法
  • Python實(shí)現(xiàn)正則表達(dá)式匹配任意的郵箱方法
  • Java使用正則表達(dá)式驗(yàn)證手機(jī)號(hào)和電話(huà)號(hào)碼的方法
  • js正則表達(dá)式校驗(yàn)指定字符串的方法
  • JS使用正則表達(dá)式獲取小括號(hào)、中括號(hào)及花括號(hào)內(nèi)容的方法示例
  • Android 2018最新手機(jī)號(hào)驗(yàn)證正則表達(dá)式方法
  • 前端正則表達(dá)式書(shū)寫(xiě)及常用的方法

標(biāo)簽:咸陽(yáng) 鞍山 池州 梅州 三亞 綿陽(yáng) 六安 恩施

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《正則表達(dá)式性能優(yōu)化方法(高效正則表達(dá)式書(shū)寫(xiě))》,本文關(guān)鍵詞  正則,表達(dá)式,性能,優(yōu)化,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問(wèn)題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無(wú)關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《正則表達(dá)式性能優(yōu)化方法(高效正則表達(dá)式書(shū)寫(xiě))》相關(guān)的同類(lèi)信息!
  • 本頁(yè)收集關(guān)于正則表達(dá)式性能優(yōu)化方法(高效正則表達(dá)式書(shū)寫(xiě))的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    主站蜘蛛池模板: 安宁市| 丘北县| 图木舒克市| 砀山县| 青川县| 永年县| 盱眙县| 太和县| 丰县| 霸州市| 志丹县| 观塘区| 巫山县| 东兰县| 武清区| 香河县| 西华县| 泰兴市| 潜山县| 新乡市| 和林格尔县| 来安县| 西林县| 南投市| 柘荣县| 清徐县| 密云县| 玉树县| 东阳市| 新宾| 黄平县| 临江市| 民丰县| 萍乡市| 隆昌县| 外汇| 通道| 封丘县| 玉环县| 桓台县| 湘阴县|