在Java中除了用split()实现字符串切割外,还可用StringTokenizer类。
StringTokenizer API
1、构造函数
public StringTokenizer(String str) {
this(str, " \t\n\r\f", false);
}
构造一个用来解析str的StringTokenizer对象。java默认的分隔符是“空格”、“制表符(‘\t’)”、“换行符(‘\n’)”、“回车符 (‘\r’)”。
public StringTokenizer(String str, String delim) {
this(str, delim, false);
}
构造一个用来解析str的StringTokenizer对象,并提供一个指定的分隔符。
public StringTokenizer(String str, String delim, boolean returnDelims) {
...
}
构造一个用来解析str的StringTokenizer对象并提供一个指定的分隔符,同时指定是否返回分隔符。
2、常用方法
int countTokens():返回nextToken方法被调用的次数。
boolean hasMoreTokens():返回是否还有分隔符。
boolean hasMoreElements():返回是否还有分隔符。
String nextToken():返回从当前位置到下一个分隔符的字符串。
Object nextElement():返回从当前位置到下一个分隔符的字符串。
String nextToken(String delim):与4类似,以指定的分隔符返回结果。
其中:
boolean hasMoreTokens():返回是否还有分隔符。
String nextToken():返回从当前位置到下一个分隔符的字符串。
最常用。
下面通过Demo介绍一下2、3构造函数的区别:
1、public StringTokenizer(String str, String delim) {
this(str, delim, false);
}
public static void method(){
String data = "John,38,Red"+"+"+"Sally,42,Blue"+"+"+"Rudy,31,Yellow"+"+";
StringTokenizer st = new StringTokenizer(data, ",+");
//输出共有几个分隔符
System.out.println("countTokens::"+st.countTokens());
while(st.hasMoreTokens()){
System.out.println(st.nextToken());
}
}
以’,’和’+’为分隔符。所以我们可以得出StringTokenizer可以多个分隔符进行分隔。
结果:
countTokens::9
John
38
Red
Sally
42
Blue
Rudy
31
Yellow
2、public StringTokenizer(String str, String delim, boolean returnDelims) {
…
}
public static void method(){
String data = "John,38,Red"+"+"+"Sally,42,Blue"+"+"+"Rudy,31,Yellow"+"+";
//输出共有几个分隔符
System.out.println("countTokens::"+st.countTokens());
StringTokenizer st = new StringTokenizer(data, ",+",true);
while(st.hasMoreTokens()){
System.out.println(st.nextToken());
}
}
结果:
countTokens::18
John
,
38
,
Red
+
Sally
,
42
,
Blue
+
Rudy
,
31
,
Yellow
+
所以可以得到这两个构造函数的区别:
StringTokenizer(String str, String delim),通过st.countTokens()将得到的是:分隔符的数据量
StringTokenizer(String str, String delim, boolean returnDelims) ,通过st.countTokens()将得到的是:分隔符的数据量+分隔符的数量