首页 > 编程知识 正文

得的用法举例说明(limit用法)

时间:2023-05-05 23:48:28 阅读:76546 作者:4613

StringTokenizer类:提供一种基于自定义字符拆分分隔符并封装结果以获取遍历值的方法。 StringTokenizer方法不区分标识符、数字和带引号的字符串,也不识别注释并跳过。 此方法的用途类似于split方法,只是封装了结果。

StringTokenizer的三个构造方法:

1.stringtokenizer(stringstr ) :分割对象str的分隔符采用默认的分割。 缺省情况下,Java分隔符为“空格”、“制表符(((() t )”、“换行符() n )”和“换行符() r )”) 652 ) 652。

源代码:

公共字符串训练器(stringstr ) {

this(str、(tnrf、false );

}

实例:

3358 www.Sina.com/viewplaincopyprint? publicstaticvoidmain (string [ ] args ) stringtokenizerst=new string tokenizer (wwoobjcom ); while(ST.hasmoreelements () (system.out.println ) ) token : (ST.next token ) ); }输出:

token :万维网

Token:ooobj

Token:com

2.stringtokenizer(stringstr,String delim ) :分隔符提供指定的分隔符,而不是默认值。

3.stringtokenizer(stringstr、String delim、boolean returnDelims ) ) :指定特定分隔符,同时指定是否返回分隔符。 如果为true,则分隔符以token形式返回。

实例:

publicstaticvoidmain (string [ ] args ) stringtokenizerst=new string tokenizer (' www.oo obj.com ','.',true ); while(ST.hasmoreelements () (system.out.println ) ) token : (ST.next token ) ); }输出: token : www token :token : ooobjtoken :token : com

方法有六种。 (所有方法均为公共型)

:Arial; font-size:14px">

int countTokens()  

   对于这个方法API的描述是这样的:Calculates the number of times that this tokenizer'snextToken method can be called before it generates an exception. The current position is not advanced. 

  它说计算nextToken方法在抛异常以前还能被调用的次数,当前索引不增加。

 其实就是说还有几个元素可以被遍历。返回的是 当前可以被访问的元素的个数。


方法1:用来判断当前还有没有可以遍历的元素

   boolean hasMoreTokens(); //判断字符串中是含还有token 

   boolean hasMoreElements();

方法2:用来获得当前的元素token,一个返回String类型,一个返回Object类型

   Object nextElement();//除返回结果类型外,其返回与 nextToken 方法相同的值

   String nextToken();//StringTokenizer对象中的下一个token。 

方法3:

 String nextToken(String delim)

 返回当前索引开始,指定分隔符的下一个token。实际返回的是索引当前位置到下一个delim出现为止所有的字符,见例子。

 无法想想出这个方法在什么情况下使用。


StringTokenizer test = new StringTokenizer("J-PHONE,Vodafone,SoftBank",",");while(test.hasMoreTokens()){System.out.println("count0="+test.countTokens());System.out.println("carry"+test.nextToken());System.out.println("count1="+test.countTokens());//System.out.println(" " + test.nextToken("*"));}

输出结果:

count0=3
carryJ-PHONE
count1=2
count0=2
carryVodafone
count1=1
count0=1
carrySoftBank
count1=0


如果代码换成element:

while(test.hasMoreElements()){System.out.println("count0="+test.countTokens());System.out.println("obj" + test.nextElement());System.out.println("count1="+test.countTokens());}

输出的结果是一样:

count0=3
objJ-PHONE
count1=2
count0=2
objVodafone
count1=1
count0=1
objSoftBank
count1=0


但是 需要注意是nextElement()返回是对象类型,不是String类型,需要根据需要转化下


还要说一个StringTokenizer比较不好的地方,就是她的索引无法返回,一旦nextToken 就不能返回了,像上面两种写法同时存在的话,只有第一个循环能有数据输出,第二个循环是不能进去的。如果哪位大侠知道返回的方法请赐教。


语句:

System.out.println("count0="+test.countTokens());
System.out.println("obj=" + test.nextElement());
System.out.println("next=" + test.nextToken("*"));
System.out.println("count1="+test.countTokens());

输出结果:

count0=2
obj=J-PHONE
next=,Vodafone
count1=1





版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。