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. ECshop网店系统百万级商品量性能优化-简单的一些Cache内存配置

    ECshop网店系统对于产品的数据.模板.Query都可以缓存,也就是把一些商品详情页.分类页.Search页的数据经过一次访问后,用文件的形式保存下来,下次有人访问相同的页面时,不用再查数据库,直接 ...

  2. 【pyhton】【转】修改递归次数

    import sys sys.setrecursionlimit(1500) # set the maximum depth as 1500 def recursion(n): if(n <= ...

  3. ORA-24010 SMG-3000

    参考:http://t.askmaclean.com/thread-528-1-1.html 运行脚本的时候一定要清楚脚本做了什么操作,注意看清脚本的报错. conn / as sysdba@?/rd ...

  4. 网络设备作用和工作ISO层

    物理层——中继器和集线器 二者都起数字信号放大和中转的作用. 中继器 Repeater 用来延长网络距离的互连设备.REPEATER可以增强线路上衰减的信号,它两端即可以连接相同的传输媒体,也可以连接 ...

  5. ubuntu 12.04 安装 nginx+php+mysql web服务器

    Nginx 是一个轻量级,以占用系统资源少,运行效率而成为web服务器的后起之秀,国内现在很多大型网站都以使用nginx,包括腾讯.新浪等大型信息网站,还有淘宝网站使用的是nginx二次开发的web服 ...

  6. iOS 日历类(NSCalendar)

    对于时间的操作在开发中很常见,但有时候我们需要获取到一年后的时间,或者一周后的时间.靠通过秒数计算是不行的.那就牵扯到另外一个日历类(NSCalendar).下面先简单看一下 NSDate let d ...

  7. iOS最新上线流程+续费 2015-7-20更新

    一.程序上线前准备 确认图标是否⻬全,应⽤的icon图标 在以前图⽚片直接命名 为icon就可以了,在xcode5以后,苹果加 ⼊入了images.xcasset这个⽂文件夹,所有的 图标全都在这⾥里 ...

  8. Emule使用Upnp,解决Lowid和port not reachable的问题

    路由器上钩选开启Upnp Emule->选择->扩展选项->Upnp, 服务器:[从URL更新]http://upd.emule-security.org/server.met

  9. centos 下 yum 安装 nginx 平滑切换安装到 Tengine

    ---恢复内容开始--- 据说淘宝的Tengine很牛X,所以我们今天也来玩玩,我们这里是某开放云的vps,现在已经安装好了nginx,现在我们要平滑切换到安装Tengine. 下载Tengine,解 ...

  10. Linux fdisk 命令

    Linux fdisk 命令 fdisk                         fdisk功能说明:磁盘分区.语 法:fdisk [-b <分区大小>][-uv][外围设备代号] ...