StringTokenizer 类的详释

来源:互联网 发布:2 100 mod5 编程 编辑:程序博客网 时间:2024/06/05 18:32

出处:http://blog.sina.com.cn/s/blog_6903cb750100mpy4.html


StringTokenizer类

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+"\" ");

          }

     }

}