国产睡熟迷奷白丝护士系列精品,中文色字幕网站,免费h网站在线观看的,亚洲开心激情在线

      <sup id="hb9fh"></sup>
          1. 千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

            手機(jī)站
            千鋒教育

            千鋒學(xué)習(xí)站 | 隨時隨地免費學(xué)

            千鋒教育

            掃一掃進(jìn)入千鋒手機(jī)站

            領(lǐng)取全套視頻
            千鋒教育

            關(guān)注千鋒學(xué)習(xí)站小程序
            隨時隨地免費學(xué)習(xí)課程

            當(dāng)前位置:首頁  >  技術(shù)干貨  > Java Matcher對象中find()與matches()的區(qū)別?

            Java Matcher對象中find()與matches()的區(qū)別?

            來源:千鋒教育
            發(fā)布人:xqq
            時間: 2023-10-11 15:00:20 1697007620

            一、Java Matcher對象中find()與matches()的區(qū)別

            find():是否存在與該模式匹配的下一個子序列。簡單來說就是在字符某部分匹配上模式就會返回true,同時匹配位置會記錄到當(dāng)前位置,再次調(diào)用時從該處匹配下一個。

            matches():整個字符串是否匹配上模式,匹配上則返回true,否則false。

            @Test

            public void patternTest() {

            ??? String str = “hellohellohello”;

            ??? String regex = “hello”;

            ??? Pattern pattern = Pattern.compile(regex);

            ??? Matcher matcher = pattern.matcher(str);

            ??? System.out.println(matcher.find());

            ??? System.out.println(matcher.matches());

            }

            輸出結(jié)果為:

            find() -> true

            matches() -> false

            再拓展兩個函數(shù),Matcher中的start()和end()。start(),點進(jìn)方法可以看到返回的是上一個匹配項的起始索引,如果沒有匹配項將拋出IllegalStateException異常。同理,end()則為結(jié)束的索引。

            好了,那我們來看一個例子:

            @Test

            public void patternTest() {

            ??? String str = “hellohellohello”;

            ??? String regex = “hello”;

            ??? Pattern pattern = Pattern.compile(regex);

            ??? Matcher matcher = pattern.matcher(str);

            ??? while (matcher.find()) {

            ????? System.out.println(matcher.start() + “->” + matcher.end());

            ??? }

            }

            輸出:

            0->5

            5->10

            10->15

            可以看出find()匹配完后會記錄當(dāng)前匹配位置知道最后。

            我們再看看另外一種情況,嘗試在matcher.matches()后面再匹配一次matcher.find()會發(fā)生什么情況?

            @Test

            public void patternTest() {

            ??? String str = “hello”;

            ??? String regex = “hello”;

            ??? Pattern pattern = Pattern.compile(regex);

            ??? Matcher matcher = pattern.matcher(str);

            ??????? System.out.println(“find() -> ” + matcher.find());

            ??? System.out.println(“matches() -> ” + matcher.matches());

            ??? System.out.println(“find() -> ” + matcher.find());

            }

            輸出結(jié)果為:

            find() -> true

            matches() -> true

            find() -> false

            matcher.find()名列前茅次為true,第二次卻為false,這將帶來了好多小問號了。我們還是進(jìn)入matches()方法看看,從this.oldLast = this.last可以看出,matches()更新了最后匹配位置,所以在使用find()去找下一個匹配位置時,就找不到了,所以為false。而如果要重置匹配位置,可以使用find(0)(說明:find(int start),重置匹配器,然后嘗試查找索引start開始的下一個滿足匹配的子序列,所以find(0)相當(dāng)于重置為最原始狀態(tài))。

            延伸閱讀:

            二、什么是Java

            Java是一門面向?qū)ο缶幊陶Z言,不僅吸收了C++語言的各種優(yōu)點,還摒棄了C++里難以理解的多繼承、指針等概念,因此Java語言具有功能強(qiáng)大和簡單易用兩個特征。Java語言作為靜態(tài)面向?qū)ο缶幊陶Z言的代表,極好地實現(xiàn)了面向?qū)ο罄碚?,允許程序員以優(yōu)雅的思維方式進(jìn)行復(fù)雜的編程 。

            聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
            10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
            請您保持通訊暢通,專屬學(xué)習(xí)老師24小時內(nèi)將與您1V1溝通
            免費領(lǐng)取
            今日已有369人領(lǐng)取成功
            劉同學(xué) 138****2860 剛剛成功領(lǐng)取
            王同學(xué) 131****2015 剛剛成功領(lǐng)取
            張同學(xué) 133****4652 剛剛成功領(lǐng)取
            李同學(xué) 135****8607 剛剛成功領(lǐng)取
            楊同學(xué) 132****5667 剛剛成功領(lǐng)取
            岳同學(xué) 134****6652 剛剛成功領(lǐng)取
            梁同學(xué) 157****2950 剛剛成功領(lǐng)取
            劉同學(xué) 189****1015 剛剛成功領(lǐng)取
            張同學(xué) 155****4678 剛剛成功領(lǐng)取
            鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
            董同學(xué) 138****2867 剛剛成功領(lǐng)取
            周同學(xué) 136****3602 剛剛成功領(lǐng)取
            相關(guān)推薦HOT
            游戲開發(fā)需要具備哪些技術(shù)?

            一、游戲開發(fā)需要具備的技術(shù)數(shù)學(xué)基礎(chǔ):根據(jù)你所做內(nèi)容來決定,一般上層邏輯比較少的去考慮到積分等高數(shù)內(nèi)容。但是如果想搞圖形學(xué),矩陣線性代數(shù)...詳情>>

            2023-10-11 16:37:20
            PHP與JAVA的本質(zhì)區(qū)別有哪些?

            一、PHP與JAVA的本質(zhì)區(qū)別1、應(yīng)用場景不同PHP通常用于Web開發(fā),而Java則可以應(yīng)用于各種領(lǐng)域,包括Web、桌面、移動等。2、編程范式不同PHP支持面...詳情>>

            2023-10-11 16:08:19
            redis、memcache、mongoDB有哪些區(qū)別?

            一、redis、memcache、mongoDB的區(qū)別1、數(shù)據(jù)模型不同Redis是一種基于鍵值對的內(nèi)存數(shù)據(jù)庫,可以支持多種數(shù)據(jù)結(jié)構(gòu),如字符串、哈希、列表、集合、...詳情>>

            2023-10-11 16:00:30
            AOP的原理是什么?

            一、AOP的原理1、切面(Aspect)切面是橫切關(guān)注點的抽象,它定義了橫切關(guān)注點在何時、何地和如何被織入到程序中。切面通常以類或者方法的形式存...詳情>>

            2023-10-11 15:58:09
            什么是linux進(jìn)程?

            一、什么是linux進(jìn)程Linux進(jìn)程是指在Linux操作系統(tǒng)上運行的程序?qū)嵗_M(jìn)程是操作系統(tǒng)中最基本的資源之一,每個進(jìn)程都具有自己的代碼、數(shù)據(jù)、內(nèi)...詳情>>

            2023-10-11 15:47:54