本文主要是介绍java.util.regex包下Pattern、Matcher类学习,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
java.util.regex包下Pattern、Matcher类学习
此文所有的程序代码地址:RegularExperssion
java.util.regex包主要包括以下三个类:
Pattern 类
Matcher 类
PatternSyntaxException 类
PatternSyntaxException 是一个非强制异常类,它表示一个正则表达式模式中的语法错误。
Pattern类
Pattern 对象是一个正则表达式的编译表示。Pattern 类没有公共构造方法。要创建一个 Pattern 对象,你必须首先调用其公共静态编译方法,它返回一个 Pattern 对象。该方法接受一个正则表达式作为它的第一个参数。
Pattern 实现类java.io中的Serializable虚拟接口。
常用方法
compile()方法:
这是Pattern类的静态编译方法,该方法就相当于一个构造方法,因为它返回一个类的示例。它的String类型参数是一个正则表达式。
/*** Compiles the given regular expression into a pattern.** @param regex* The expression to be compiled* @return the given regular expression compiled into a pattern* @throws PatternSyntaxException* If the expression's syntax is invalid*/ public static Pattern compile(String regex) {return new Pattern(regex, 0); }public static Pattern compile(String regex, int flags) {return new Pattern(regex, flags); }
其中参数flags是表明匹配模式,下面是取值说明,这些都是 Pattern 类的静态常量(final类型)
* @param flags* Match flags, a bit mask that may include* {@link #CASE_INSENSITIVE}, {@link #MULTILINE}, {@link #DOTALL},* {@link #UNICODE_CASE}, {@link #CANON_EQ}, {@link #UNIX_LINES},* {@link #LITERAL}, {@link #UNICODE_CHARACTER_CLASS}* and {@link #COMMENTS}
toString()方法:返回模板的字符串形式
/*** <p>Returns the string representation of this pattern. This* is the regular expression from which this pattern was* compiled.</p>** @return The string representation of this pattern* @since 1.5*/ public String toString() {return pattern; }
matcher():用于获得Matcher对象的一个方法,该方法接收一个被判定的序列作为参数。其中compiled是一个boolean类型成员变量,初始值为false,以记录该pattern是否被编译。
/*** Creates a matcher that will match the given input against this pattern.** @param input* The character sequence to be matched** @return A new matcher for this pattern*/ public Matcher matcher(CharSequence input) {if (!compiled) {synchronized(this) {if (!compiled)compile();}}Matcher m = new Matcher(this, input);return m; }
matches():匹配搜索,返回boolean值,实际上 String 类中的 matches 方法正是调用的此方法。
public static boolean matches(String regex, CharSequence input) {Pattern p = Pattern.compile(regex);Matcher m = p.matcher(input);return m.matches(); }
Matcher类
该类实现了 MatchResult 接口。
Matcher类没有提供什么静态方法,通过调用 Pattern 对象的 matcher 方法来获得一个 Matcher 对象,如:
Pattern pattern = Pattern.compile(“regExp”);
Matcher matcher = pattern.matcher(“string”);
此时我们就得到了一个Matcher对象,通过此对象就可以对字符串进行操作了。
构造方法
友好的而并非public,所以,并没有公共默认的构造方法,需要 Pattern 的 matcher() 方法。在第二个方法中我们可以看到匹配完成之后,此对象又将返回初始化状态。
/*** No default constructor.*/
Matcher() {
}/*** All matchers have the state used by Pattern during a match.*/
Matcher(Pattern parent, CharSequence text) {this.parentPattern = parent;this.text = text;// Allocate state storageint parentGroupCount = Math.max(parent.capturingGroupCount, 10);groups = new int[parentGroupCount * 2];locals = new int[parent.localCount];// Put fields into initial statesreset();
}
reset ( )
重新设置方法。这个方法被重载,可以用一个新的序列来重设这个对象,但最后还是调用了无参的方法。
/*** Resets this matcher.** <p> Resetting a matcher discards all of its explicit state information* and sets its append position to zero. The matcher's region is set to the* default region, which is its entire character sequence. The anchoring* and transparency of this matcher's region boundaries are unaffected.** @return This matcher*/
public Matcher reset() {first = -1;last = 0;oldLast = -1;for(int i=0; i<groups.length; i++)groups[i] = -1;for(int i=0; i<locals.length; i++)locals[i] = -1;lastAppendPosition = 0;from = 0;to = getTextLength();
return this;
}/*** Resets this matcher with a new input sequence.** <p> Resetting a matcher discards all of its explicit state information* and sets its append position to zero. The matcher's region is set to* the default region, which is its entire character sequence. The* anchoring and transparency of this matcher's region boundaries are* unaffected.** @param input* The new input character sequence** @return This matcher*/
public Matcher reset(CharSequence input) {text = input;
return reset();
}
这篇关于java.util.regex包下Pattern、Matcher类学习的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!