zxzheaven 2010-01-12 10:24
浏览 235
已采纳

遍历字符串每个字符,Stringreader是不是要比string.toCharArray来的快?

我想遍历一个字符串的每一个字符,以前是用string.toCharArray()来转换成一个char[]一个一个看的

不过我看到有些,特别是lucene的分词器,他们都是用的stringreader来遍历一个字符串的

是不是stringreader要比string.toCharArray()换成的char[]要来的快?

  • 写回答

6条回答 默认 最新

  • 拽拽的初行者 2010-01-12 10:36
    关注

    [color=blue]应该是string.toCharArray()速度快吧。我的理由如下:[/color]
    [b]看StringReader的read方法的JDK源码:[/b]
    [code="java"]
    public int read() throws IOException {
    synchronized (lock) {
    ensureOpen();
    if (next >= length)
    return -1;
    return str.charAt(next++);
    }
    }
    [/code]
    [color=blue]可以看到,在读取一个字符时,用到的是String的字符索引方法。与toCharArray之后的遍历相比,其操作比较繁琐。
    因此我认为String的toCharArray之后,再遍历数组,速度比较快![/color]

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(5条)

报告相同问题?

悬赏问题

  • ¥15 数学的三元一次方程求解
  • ¥20 iqoo11 如何下载安装工程模式
  • ¥15 本题的答案是不是有问题
  • ¥15 关于#r语言#的问题:(svydesign)为什么在一个大的数据集中抽取了一个小数据集
  • ¥15 C++使用Gunplot
  • ¥15 这个电路是如何实现路灯控制器的,原理是什么,怎么求解灯亮起后熄灭的时间如图?
  • ¥15 matlab数字图像处理频率域滤波
  • ¥15 在abaqus做了二维正交切削模型,给刀具添加了超声振动条件后输出切削力为什么比普通切削增大这么多
  • ¥15 ELGamal和paillier计算效率谁快?
  • ¥15 蓝桥杯单片机第十三届第一场,整点继电器吸合,5s后断开出现了问题