出处:http://blog.sina.com.cn/s/blog_6903cb750100mpy4.html
Java语言中,提供了专门用来分析字符串的类StringTokenizer(位于java.util包中)。该类可以将字符串分解为独立使用的单词,并称之为语言符号。语言符号之间由定界符(delim)或者是空格、制表符、换行符等典型的空白字符来分隔。其他的字符也同样可以设定为定界符。StringTokenizer类的构造方法及描述见表15-6所示。
表15-6 StringTokenizer类的构造方法及描述
构 造 方 法 |
描 述 |
StringTokenizer(String str) |
为字符串str构造一个字符串分析器。使用默认的定界符,即空格符(如果有多个连续的空格符,则看作是一个)、换行符、回车符、Tab符号等 |
StringTokenizer(String str, String delim) |
为字符串str构造一个字符串分析器,并使用字符串delim作为定界符 |
StringTokenizer类的主要方法及功能见表15-7所示。
表15-7 StringTokenizer类的主要方法及功能
方 法 |
功 能 |
String nextToken() |
用于逐个获取字符串中的语言符号(单词) |
boolean hasMoreTokens() |
用于判断所要分析的字符串中,是否还有语言符号,如果有则返回true,反之返回false |
int countTokens() |
用于得到所要分析的字符串中,一共含有多少个语言符号 |
代码15-7中,举例说明StringTokenizer类、类中方法的使用。程序分析两个字符串,统计字符串中单词的个数。
代码15-7 StringTokenizer类的使用StringTokenizerDemo.java
import java.util.*;
public class StringTokenizerDemo
{
public static void main(String[] args)
{
String str1 = "Helloworld!This is Java code,stringTokenizer Demo.";
//声明并初始化字符串str1
String str2 = "How to useStringTokenizer?StringTokenizer?";
//声明并初始化字符串str2
StringTokenizer strT1 = newStringTokenizer(str1," ,.!");
//创建StringTokenizer类的对象strT1,并构造字符串str1的分析器
//以空格符、","、"."及"!"作为定界符
StringTokenizer strT2 = newStringTokenizer(str2," ?");
//创建StringTokenizer类的对象strT2,并构造字符串str2的分析器
//以空格符及"?"作为定界符
int num1 =strT1.countTokens();
//获取字符串str1中语言符号的个数
int num2 =strT2.countTokens();
//获取字符串str2中语言符号的个数
System.out.println("str1 has"+num1+" words.They are:");
while(strT1.hasMoreTokens())
{ //利用循环来获取字符串str1中下一个语言符号,并输出
String str = strT1.nextToken();
System.out.print("\""+str+"\" ");
}
System.out.println("\nstr2 has"+num2+" words.They are:");
while(strT2.hasMoreTokens())
{ //利用循环来获取字符串str2中下一个语言符号,并输出
String str =strT2.nextToken();
System.out.print("\""+str+"\" ");
}
}
}