本篇內(nèi)容介紹了“Java正則表達(dá)式匹配模式的用法”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來(lái)就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!
公司主營(yíng)業(yè)務(wù):網(wǎng)站設(shè)計(jì)、成都做網(wǎng)站、移動(dòng)網(wǎng)站開發(fā)等業(yè)務(wù)。幫助企業(yè)客戶真正實(shí)現(xiàn)互聯(lián)網(wǎng)宣傳,提高企業(yè)的競(jìng)爭(zhēng)能力。創(chuàng)新互聯(lián)公司是一支青春激揚(yáng)、勤奮敬業(yè)、活力青春激揚(yáng)、勤奮敬業(yè)、活力澎湃、和諧高效的團(tuán)隊(duì)。公司秉承以“開放、自由、嚴(yán)謹(jǐn)、自律”為核心的企業(yè)文化,感謝他們對(duì)我們的高要求,感謝他們從不同領(lǐng)域給我們帶來(lái)的挑戰(zhàn),讓我們激情的團(tuán)隊(duì)有機(jī)會(huì)用頭腦與智慧不斷的給客戶帶來(lái)驚喜。創(chuàng)新互聯(lián)公司推出寧晉免費(fèi)做網(wǎng)站回饋大家。
Greediness(貪婪型):最大匹配
X?、X*、X+、X{n,} 是最大匹配。例如你要用 “<.+>” 去匹配 “a
在 Greediness 的模式下,會(huì)盡量大范圍的匹配,直到匹配了整個(gè)內(nèi)容,這時(shí)發(fā)現(xiàn)匹配不能成功時(shí),開始回退縮小匹配范圍,直到匹配成功
String test = "aaava abb "; String reg = "<.+>"; System.out.println(test.replaceAll(reg, "###"));
輸出:a###abb
Reluctant(Laziness)(勉強(qiáng)型):最小匹配
X??、X*?、X+?、X{n,}? 是最小匹配,其實(shí)X{n,m}?和X{n }?有些多余。在 Greediness 模式之后添加 ? 就成最小匹配。
在 Reluctant 的模式下,只要匹配成功,就不再繼續(xù)嘗試匹配更大范圍的內(nèi)容
String test = "aaava abb "; String reg = "<.+?>"; System.out.println(test.replaceAll(reg, "###"));
輸出:a###aava ###abb
與 Greediness 不同,Reluctant 模式下匹配了兩次內(nèi)容
Possessive(占有型):完全匹配
X?+、X*+、X++、X{n,}+ 是完全匹配,在 Greediness 模式之后添加 + 就成完全匹配。
Possessive 模式與 Greediness 有一定的相似性,那就是都盡量匹配最大范圍的內(nèi)容,直到內(nèi)容結(jié)束,但與 Greediness 不同的是,完全匹配不再回退嘗試匹配更小的范圍。
String test = "aaava abb "; String reg = "<.++>"; String test2 = ""; String reg2 = " "; System.out.println(test.replaceAll(reg, "###")); System.out.println(test2.replaceAll(reg2, "###")); 輸出:a
aava abb“Java正則表達(dá)式匹配模式的用法”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注創(chuàng)新互聯(lián)網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!
本文標(biāo)題:Java正則表達(dá)式匹配模式的用法
網(wǎng)站URL:http://weahome.cn/article/jcipic.html