Java中substring方法可以分解字符串,返回的是原字符串的一個子字符串。如果要講一個字符串分解為一個一個的單詞或者標記,StringTokenizer可以幫你。
先看個例子:
- public static void main(String[] args) {
- StringTokenizer st = new StringTokenizer("www.ooobj.com", ".b");
- while(st.hasMoreElements()){
- System.out.println("Token:" + st.nextToken());
- }
- }
輸出:
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)。默認以” \t\n\r\f”(前有一個空格,引號不是)為分割符。
源碼:
public StringTokenizer(String str) {
this(str, ” \t\n\r\f”, false);
}
實例:
- public static void main(String[] args) {
- StringTokenizer st = new StringTokenizer("www ooobj com");
- while(st.hasMoreElements()){
- System.out.println("Token:" + st.nextToken());
- }
- }
輸出:
Token:www
Token:ooobj
Token:com
2.StringTokenizer(String str, String delim)。指定delim為分割符,看第一個例子。
3.StringTokenizer(String str, String delim, boolean returnDelims)。returnDelims為true的話則delim分割符也被視為標記。
實例:
輸出:
Token:www
Token:.
Token:ooobj
Token:.
Token:com