<pre name="code" class="java">public class TestStringTokenizer {
public static void main(String[] args) {
StringTokenizer st=new StringTokenizer("i@love@java", "@");
while(st.hasMoreElements()){
System.out.println(st.nextToken());
}
}
}
输出结果:
i
love
java
StringTokenizer有两个常用的方法:
1.hasMoreTokens()。这个方法和hasMoreElements()方法的用法是一样的,只是StringTokenizer为了实现Enumeration接口而实现的方法,从StringTokenizer的声明可以看到:class StringTokenizer implements Enumeration<Object>。
2.nextElement()。这个方法和nextToken()方法的用法是一样的,返回此 StringTokenizer 的下一个标记。
StringTokenizer的三个构造方法:
1.StringTokenizer(String str)。默认以” \t\n\r\f”(前有一个空格,引号不是)为分割符。
源码:
public StringTokenizer(String str) {
this(str, ” \t\n\r\f”, false);
}
实例:
输出:
Token:I
Token:love
Token:java
2.StringTokenizer(String str, String delim)。指定delim为分割符,看第一个例子。
3.StringTokenizer(String str, String delim, boolean returnDelims)。returnDelims为true的话则delim分割符也被视为标记。
实例:
输出:
Token:www
Token:.
Token:baidu
Token:.
Token:com
StringTokenizer与String的split、substring比较:
最终,StringTokenizer在截取字符串中效率最高,不论数据量大小,几乎持平。substring则要次之,数据量增加耗时也要随之增加。split则是表现最差劲的。