StringTokenizer最快 ,基本已经不用了,除非在某些需要效率的场合。
Scanner最慢。 
String和Pattern速度差不多。Pattern稍快些。 String和Pattern的split 方法效率相当,常用

  1. public   static   void  main(String [] args){
  2. long  start = System.currentTimeMillis();
  3. for ( int  i= 0 ;i< 100000 ;i++){
  4. test1();
  5. }
  6. long  end = System.currentTimeMillis();
  7. System.out.println("StringTokenzier: " +(end-start));
  8. start = System.currentTimeMillis();
  9. for ( int  i= 0 ;i< 100000 ;i++){
  10. test2();
  11. }
  12. end = System.currentTimeMillis();
  13. System.out.println("Scanner: " +(end-start));
  14. start = System.currentTimeMillis();
  15. for ( int  i= 0 ;i< 100000 ;i++){
  16. test3();
  17. }
  18. end = System.currentTimeMillis();
  19. System.out.println("String: " +(end-start));
  20. start = System.currentTimeMillis();
  21. for ( int  i= 0 ;i< 100000 ;i++){
  22. test4();
  23. }
  24. end = System.currentTimeMillis();
  25. System.out.println("Pattern: " +(end-start));
  26. }
  27. //用StringTokenizer
  28. public   static   void  test1(){
  29. String input = "This is 1 just a test" ;
  30. StringTokenizer st = new  StringTokenizer(input);
  31. while (st.hasMoreTokens()){
  32. String s = st.nextToken();
  33. }
  34. }
  35. //用Scanner的方法
  36. public   static   void  test2(){
  37. String input = "This is 1 just a test" ;
  38. Scanner scanner = new  Scanner(input);
  39. scanner.useDelimiter(" " );
  40. while (scanner.hasNext()){
  41. String s = scanner.next();
  42. }
  43. }
  44. //用String的split方法
  45. public   static   void  test3(){
  46. String input = "This is 1 just a test" ;
  47. String [] str = input.split(" " );
  48. for ( int  i= 0 ;i<str.length;i++){
  49. String s = str[i];
  50. }
  51. }
  52. //用Pattern的方法
  53. public   static   void  test4(){
  54. Pattern pattern = Pattern.compile(" " );
  55. String input = "This is 1 just a test" ;
  56. String [] str = pattern.split(input);
  57. for ( int  i= 0 ;i<str.length;i++){
  58. String s = str[i];
  59. }
  60. }
  1. public static void main(String [] args){
  2. long start = System.currentTimeMillis();
  3. for(int i=0;i<100000;i++){
  4. test1();
  5. }
  6. long end = System.currentTimeMillis();
  7. System.out.println("StringTokenzier: "+(end-start));
  8. start = System.currentTimeMillis();
  9. for(int i=0;i<100000;i++){
  10. test2();
  11. }
  12. end = System.currentTimeMillis();
  13. System.out.println("Scanner: "+(end-start));
  14. start = System.currentTimeMillis();
  15. for(int i=0;i<100000;i++){
  16. test3();
  17. }
  18. end = System.currentTimeMillis();
  19. System.out.println("String: "+(end-start));
  20. start = System.currentTimeMillis();
  21. for(int i=0;i<100000;i++){
  22. test4();
  23. }
  24. end = System.currentTimeMillis();
  25. System.out.println("Pattern: "+(end-start));
  26. }
  27. //用StringTokenizer
  28. public static void test1(){
  29. String input = "This is 1 just a test";
  30. StringTokenizer st = new StringTokenizer(input);
  31. while(st.hasMoreTokens()){
  32. String s = st.nextToken();
  33. }
  34. }
  35. //用Scanner的方法
  36. public static void test2(){
  37. String input = "This is 1 just a test";
  38. Scanner scanner = new Scanner(input);
  39. scanner.useDelimiter(" ");
  40. while(scanner.hasNext()){
  41. String s = scanner.next();
  42. }
  43. }
  44. //用String的split方法
  45. public static void test3(){
  46. String input = "This is 1 just a test";
  47. String [] str = input.split(" ");
  48. for(int i=0;i<str.length;i++){
  49. String s = str[i];
  50. }
  51. }
  52. //用Pattern的方法
  53. public static void test4(){
  54. Pattern pattern = Pattern.compile(" ");
  55. String input = "This is 1 just a test";
  56. String [] str = pattern.split(input);
  57. for(int i=0;i<str.length;i++){
  58. String s = str[i];
  59. }
  60. }

运行了五次。输出结果如下:

  1. StringTokenzier:  110
  2. Scanner: 3281
  3. String: 453
  4. Pattern: 438
  5. StringTokenzier: 109
  6. Scanner: 3297
  7. String: 453
  8. Pattern: 438
  9. StringTokenzier: 110
  10. Scanner: 3265
  11. String: 485
  12. Pattern: 437
  13. StringTokenzier: 109
  14. Scanner: 3266
  15. String: 469
  16. Pattern: 437
  17. StringTokenzier: 109
  18. Scanner: 3297
  19. String: 469
  20. Pattern: 422
  1. StringTokenzier: 110
  2. Scanner: 3281
  3. String: 453
  4. Pattern: 438
  5. StringTokenzier: 109
  6. Scanner: 3297
  7. String: 453
  8. Pattern: 438
  9. StringTokenzier: 110
  10. Scanner: 3265
  11. String: 485
  12. Pattern: 437
  13. StringTokenzier: 109
  14. Scanner: 3266
  15. String: 469
  16. Pattern: 437
  17. StringTokenzier: 109
  18. Scanner: 3297
  19. String: 469
  20. Pattern: 422

StringTokenizer最快 
Scanner最慢。 
String和Pattern速度差不多。Pattern稍快些。

java中字符串切割的方法总结的更多相关文章

  1. 【转】Java中字符串中子串的查找共有四种方法(indexof())

    原文网址:http://wfly2004.blog.163.com/blog/static/1176427201032692927349/ Java中字符串中子串的查找共有四种方法,如下:1.int ...

  2. Java中字符串中子串的查找共有四种方法(indexof())

    Java中字符串中子串的查找共有四种方法(indexof()) Java中字符串中子串的查找共有四种方法,如下:1.int indexOf(String str) :返回第一次出现的指定子字符串在此字 ...

  3. Java中字符串的一些常见方法

    1.Java中字符串的一些常见方法 /** * */ package com.you.model; /** * @author Administrator * @date 2014-02-24 */ ...

  4. Java中字符串indexof() 的使用方法

    Java中字符串中子串的查找共有四种方法(indexof())indexOf 方法返回一个整数值,指出 String 对象内子字符串的开始位置.如果没有找到子字符串,则返回-1.如果 startind ...

  5. 三张图彻底了解Java中字符串的不变性

    转载: 三张图彻底了解Java中字符串的不变性 定义一个字符串 String s = "abcd"; s中保存了string对象的引用.下面的箭头可以理解为"存储他的引用 ...

  6. java中字符串String 转 int(转)

    java中字符串String 转 int String -> int s="12345"; int i; 第一种方法:i=Integer.parseInt(s); 第二种方法 ...

  7. java中substring的使用方法

    java中substring的使用方法 str=str.substring(int beginIndex);截取掉str从首字母起长度为beginIndex的字符串,将剩余字符串赋值给str: str ...

  8. [java,2017-05-16] java中清空StringBuffer的方法以及耗费时间比较

    java中清空StringBuffer的方法,我能想到的有4种: 1. buffer.setLength(0);  设置长度为0 2. buffer.delete(0, buffer.length() ...

  9. Java中字符串string的数据类型

    Java中字符串string的数据类型 时间:2017-07-03 08:01:47 YuanMxy 原文:https://blog.csdn.net/YuanMxy/article/details/ ...

随机推荐

  1. Linux下简易蜂鸣器驱动代码及测试实例

    驱动代码: #include <linux/module.h> #include <linux/kernel.h> #include <linux/init.h> ...

  2. python获取系统时间

    import time print time.time() 输出的结果是: 1279578704.6725271 但是这样是一连串的数字不是我们想要的结果,我们可以利用time模块的格式化时间的方法来 ...

  3. hive 存储格式

    hive有textFile,SequenceFile,RCFile三种文件格式. textfile为默认格式,建表时不指定默认为这个格式,导入数据时会直接把数据文件拷贝到hdfs上不进行处理. Seq ...

  4. Android初步 简单demo

    刚入门不久,没学JAVA,从C++转过来的,C++的QT和安卓简直有异曲同工之妙,为了加深自己对安卓的理解,特写博客以记录,望大神们多多指点. 效果图,刚入门的话,肯定要熟悉基本的控件的使用,这跟我学 ...

  5. 对于数组使用sizeof(a)和使用sizeof(a[0])

    #include "stdafx.h" #include <iostream> using namespace std; int main() { ]={}; cout ...

  6. MyBatis之传入参数——parameterType(转)

    鸣谢:http://blog.csdn.net/liaoxiaohua1981/article/details/6862764 ------------------------------------ ...

  7. 【win8技巧】应用商店里面如何搜索应用app

    win8应用商店搜索app软件的技巧 1.组合键 WIN+C 打开屏幕最右边磁条 2.点击搜索,输入你想搜的软件名称,里面会列出你已经安装的app或者你点击下面的应用商店选项,就可以搜索互联网上应用商 ...

  8. Android+Junit单元测试1

    学习参考: http://my.oschina.net/liux/blog/52469 http://mobile.51cto.com/android-229614.htm 一,权限配置 <ap ...

  9. jQuery 在IE下对表单中input type="file"的属性值清除

    对一个文件域(input type=file)使用了验证后,我们总会希望把文件域中的值给清空了,在IE中,由于安全设置的原因,是不允许更改文件域的值的,接下来为大家介绍一下解决方法 一般来说,在对一个 ...

  10. [dp]HDOJ4960 Another OCD Patient

    题意: 给一个n, 第二行给n堆的价值v[i], 第三行给a[i].  a[i]表示把i堆合在一起需要的花费. 求把n堆变成类似回文的 需要的最小花费. 思路: ①记忆化搜索 比较好理解... dp[ ...