StringTokenizer

Java中substring方法可以分解字符串,返回的是原字符串的一个子字符串。如果要讲一个字符串分解为一个一个的单词或者标记,StringTokenizer可以帮你。

先看个例子:

[java] view plain copy
 
 print?
  1. public static void main(String[] args) {  
  2.  StringTokenizer st = new StringTokenizer("www.ooobj.com", ".b");  
  3.  while(st.hasMoreElements()){  
  4.  System.out.println("Token:" + st.nextToken());  
  5.  }  
  6.  }  


输出:
Token:www
Token:ooo
Token:j
Token:com

StringTokenizer有两个常用的方法:

1.hasMoreElements()。这个方法和hasMoreElements()方法的用法是一样的,只是StringTokenizer为了实现Enumeration接口而实现的方法,从StringTokenizer的声明可以看到:class StringTokenizer implements Enumeration<Object>。

2.nextElement()。这个方法和nextToken()方法的用法是一样的,返回此 StringTokenizer 的下一个标记。

StringTokenizer的三个构造方法:

1.StringTokenizer(String str)。默认以” f”(前有一个空格,引号不是)为分割符。
源码:
public StringTokenizer(String str) {
this(str, ” f”, false);
}

实例:

[java] view plain copy
 
 print?
  1. public static void main(String[] args) {  
  2.  StringTokenizer st = new StringTokenizer("www ooobj com");  
  3.  while(st.hasMoreElements()){  
  4.  System.out.println("Token:" + st.nextToken());  
  5.  }  
  6.  }  


输出:
Token:www
Token:ooobj
Token:com

2.StringTokenizer(String str, String delim)。指定delim为分割符,看第一个例子。

3.StringTokenizer(String str, String delim, boolean returnDelims)。returnDelims为true的话则delim分割符也被视为标记。

实例:

  public static void main(String[] args) {  

  StringTokenizer st = new StringTokenizer("www.ooobj.com", ".", true);  

  while(st.hasMoreElements()){  

  System.out.println("Token:" + st.nextToken());  

  }  

  } 

输出:
Token:www
Token:.
Token:ooobj
Token:.
Token:com

原文地址:https://www.cnblogs.com/yelongsan/p/6482545.html