久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

    1. <style id="76ofp"></style>

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

        手機(jī)站
        千鋒教育

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

        千鋒教育

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

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

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

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

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

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

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

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

        matches():整個(gè)字符串是否匹配上模式,匹配上則返回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

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

        好了,那我們來看一個(gè)例子:

        @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()匹配完后會(huì)記錄當(dāng)前匹配位置知道最后。

        我們?cè)倏纯戳硗庖环N情況,嘗試在matcher.matches()后面再匹配一次matcher.find()會(huì)發(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,這將帶來了好多小問號(hào)了。我們還是進(jìn)入matches()方法看看,從this.oldLast = this.last可以看出,matches()更新了最后匹配位置,所以在使用find()去找下一個(gè)匹配位置時(shí),就找不到了,所以為false。而如果要重置匹配位置,可以使用find(0)(說明:find(int start),重置匹配器,然后嘗試查找索引start開始的下一個(gè)滿足匹配的子序列,所以find(0)相當(dāng)于重置為最原始狀態(tài))。

        延伸閱讀:

        二、什么是Java

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

        聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
        10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
        請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
        免費(fèi)領(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)用場(chǎng)景不同PHP通常用于Web開發(fā),而Java則可以應(yīng)用于各種領(lǐng)域,包括Web、桌面、移動(dòng)等。2、編程范式不同PHP支持面...詳情>>

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

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

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

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

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

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

        2023-10-11 15:47:54
        平陆县| 横峰县| 读书| 宜州市| 万载县| 土默特右旗| 东丽区| 肇庆市| 博湖县| 潜山县| 容城县| 凌云县| 昂仁县| 崇州市| 视频| 壶关县| 通化市| 扬中市| 喀喇沁旗| 盐城市| 华容县| 和平区| 临漳县| 潍坊市| 丰城市| 饶河县| 余庆县| 黄龙县| 招远市| 肥乡县| 汾阳市| 秦皇岛市| 永州市| 丰顺县| 宜兰市| 鸡东县| 寻乌县| 汉中市| 文成县| 华亭县| 偃师市|