关于split与StringTokenizer的理解
关于split与StringTokenizer的理解
一.split
依据匹配给定的正則表達式来拆分此字符串。此方法返回的数组包括此字符串的子字符串,每一个子字符串都由还有一个匹配给定表达式的子字符串终止,或者由此字符串末尾终止。数组中的子字符串按它们在此字符串中出现的顺序排列。假设表达式不匹配输入的不论什么部分,那么所得数组仅仅具有一个元素,即此字符串。
String[] split(String regex,int limit)此方法的运用在API中得非常具体.
limit 參数控制模式应用的次数,因此影响所得数组的长度。假设该限制 n 大于 0,则模式将被最多应用 n - 1 次,数组的长度将不会大于 n,并且数组的最后一项将包括全部超出最后匹配的定界符的输入。假设 n 为非正,那么模式将被应用尽可能多的次数,并且数组能够是不论什么长度。假设 n 为 0,那么模式将被应用尽可能多的次数,数组能够是不论什么长度,并且结尾空字符串将被丢弃。
比如,字符串 "boo:and:foo" 使用这些參数可生成下面结果:
Regex
Limit
结果
:
2
{ "boo", "and:foo" }
:
5
{ "boo", "and", "foo" }
:
-2
{ "boo", "and", "foo" }
o
5
{ "b", "", ":and:f", "", "" }
o
-2
{ "b", "", ":and:f", "", "" }
o
0
{ "b", "", ":and:f" }
调用此方法的 str.split(regex, n) 形式与下面表达式产生的结果全然同样:
Pattern.compile(regex).split(str, n)
对于字符串的切割处理使用split是想当方便的...
二.StringTokenizer
stringtokenizer 类同意应用程序将字符串分解为标记。在该类中包括了几个重要的方法.
int CountTokens() 计算在生成异常之前能够调用此 tokenizer 的 nextToken 方法的次数。
boolean hasMoreElements()返回与 hasMoreTokens 方法同样的值。
boolean hasMoreTokens()測试此 tokenizer 的字符串中是否还有很多其它的可用标记。
Object nextElement()除了其声明返回值是 Object 而不是 String 之外,它返回与 nextToken 方法同样的值。
String nextToken()返回此 string tokenizer 的下一个标记。
StringTokenizer 是出于兼容性的原因而被保留的遗留类(尽管在新代码中并不鼓舞使用它)。建议全部寻求此功能的人使用 String 的 split 方法或java.util.regex 包。
三.一个面试题
对一个字符串,单词之间以空格切割,试以单词为单位反序打印(如:I Love China结果为:China Love I)
做的细想通常是将该字符串中的每一个单词保存在String[]里然后反序打印,这里就须要字符串切割的方法了...
使用split:
- static String str = "I Love China";
- public static void splitTest() {
- String[] result = str.split(" ",-1);
- for(int i = result.length - 1; i >= 0; i--) {
- System.out.print(result[i] + " ");
- }
- }
使用StringTokenizer:
- static String str = "I Love China";
- public static void StringTokenizerTest() {
- StringTokenizer st = new StringTokenizer(str);
- String[] strArray = new String[st.countTokens()];
- for (int i = strArray.length - 1; i >= 0; i--) {
- strArray[i] = st.nextToken() + " ";
- }
- for(String s : strArray) {
- System.out.print(s);
- }
- }//看上去此方法有点多此一举,使用split更为方便
关于split与StringTokenizer的理解的更多相关文章
- java中subString、split、stringTokenizer三种截取字符串方法的性能比较(转)
最近在阅读java.lang下的源码,读到String时,突然想起面试的时候曾经被人问过:都知道在大数据量情况下,使用String的split截取字符串效率很低,有想过用其他的方法替代吗?用什么替代? ...
- StringTokenizer(字符串分隔解析类型)
java.util.StringTokenizer 功效:将字符串以定界符为界,分析为一个个的token(可理解为单词),定界符可以自己指定. 1.构造函数. 1. StringTokenizer( ...
- Linux大文件分割split和合并cat使用方法
本文主要介绍linux下两个命令:split和cat.其中,相信大家都熟悉cat命令,一般用来查看一个文件的内容,但是它还其它的功能,比如这里要介绍的文件合并功能,它可把多个文件内容合并到一个文件中. ...
- Java StringTokenizer Example
In Java, you can use StringTokennizer class to split a String into different tokenas by defined deli ...
- 使用StringTokenizer分解字符串
Java切割字符串.一般使用substring.split.StringTokenizer来处理,前两种是String对象的方法,使用字符串能够直接处理,本文介绍下StringTokenizer的使用 ...
- Java-Runoob-高级教程-实例-字符串:08. Java 实例 - 字符串分割(StringTokenizer)
ylbtech-Java-Runoob-高级教程-实例-字符串:08. Java 实例 - 字符串分割(StringTokenizer) 1.返回顶部 1. Java 实例 - 字符串分隔(Strin ...
- String高效编程优化(Java)
1, substring截取超大字符串可能造成的“内存泄漏” 2,+ 操作符的优化和局限 3,StringBuilder和StringBuffer 4,split和StringTokenizer做简单 ...
- HBase介绍及简易安装(转)
HBase介绍及简易安装(转) HBase简介 HBase是Apache Hadoop的数据库,能够对大型数据提供随机.实时的读写访问,是Google的BigTable的开源实现.HBase的目标是存 ...
- MapReduce 简单的全文搜索
上一个已经实现了反向索引,那么为什么不尝试下全文搜索呢.例如有了 Hello file3.txt:1; MapReduce file3.txt:2;fil1.txt:1;fil2.tx ...
随机推荐
- Android NDK 简单介绍、工具安装、环境配置
NDK全称:Native Development Kit. 1.NDK是一系列工具的集合. * NDK提供了一系列的工具,帮助开发人员高速开发C(或C++)的动态库,并能自己主动将so和java应用一 ...
- [置顶] ARM-Linux下WEB服务器Boa的移植、配置和运行测试
Linux下使用的轻量级WEB服务器主要有:lighttpd.thttpd.shttpd和boa等等,而Boa是使用最为广泛的轻量级WEB服务器之一(当然,阿帕奇是世界使用排名第一的Web服务器软件) ...
- 自己总结的ruby on rails 查询方法
闲来无事,结合以前的代码,总结了ruby on rails的查询方法,方便自己以后查看,也方便后来人,如下,欢迎批评指正 1::simpleDB modules = find(:all, :condi ...
- hdu 4090 GemAnd Prince
题目大意: 别人说是消消看,至于你玩没玩过.反正我是没玩过的. 就是选择一个钻石,可以消除与它相连的所有钻石.并获得 消除数量*消除数量 的分 思路: 直接暴搜,然后用一个cnt数组表示每一种钻石剩 ...
- C 文件直接包含
C 文件直接包含 有一部分代码很大,在很多函数中重复,可以直接写在另外的一个文件中,引用时直接包含.co.cpp两个函数都 包含c1.cxx. 点击(此处)折叠或打开 ////// co.cpp #i ...
- NumPy简明教程
源地址:http://blog.csdn.net/sunny2038/article/details/9002531 http://blog.csdn.net/sunny2038/article/de ...
- 与内存有关的那些事儿(数组分配空间不够,导致缓冲区溢出,从而strcpy会出现异常)
这日,我写下如下代码:#include <iostream>int main(void){ char *p = new char[5]; char *t = new char[5]; st ...
- (萌O(∩_∩)O)哈希知识点小结
噶呜~先来了解一下什么是哈希吧? 当我们要在一堆东西中找到想要的那一个东西,我们常常通过比较来找,理想的情况是不经过任何比较,一次就能找到,怎么才能做到这样呢?那就在记录的储存位置和他的关键字之间建立 ...
- efwplus框架
此框架得到博客园大神@张善友的关注,建议我写一篇此框架的最新介绍,好在@dotNet跨平台公众号上推荐给大家,得到大神的指示当然激动,马不停蹄的赶出此文,供大家参考! 一.使用efwplus框架的 ...
- 14.3.4 Phantom Rows 幻影行
14.3.4 Phantom Rows 幻影行 所谓的幻读为发生在一个事务 当相同的查询产生不同的结果集在不同的时间. 比如,如果一个SELECT被执行2次, 但是第2次返回的记录不是第一次返回的记录 ...