我们正在使用
Java SAX来解析非常大的XML文件.我们的角色实现如下:
@Override public void characters(char ch[],int start,int length) throws SAXException { String value = String.copyValueOf(ch,start,length); ... }
(由SAX传递的ch []数组往往很长)
但是我们最近遇到了一些性能问题,并且分析器向我们展示了超过20%的cpu使用率高于String.copyValueOf的调用(它调用了新的String(ch,length)).
有没有更有效的方法从字符数组中获取String,起始索引和长度比String.copyValueOf(ch,length)或new String(ch,length)?
解决方法
好问题,但我敢肯定,答案是肯定的.
这是因为任何String对象构造都使用数组复制方法.它不能直接在存在的数组上构造,因为String对象必须是不可变的,并且其内部字符串数组表示是从外部更改封装的.
此外,在您的情况下,您处理某个数组的片段.不可能以任何方式在另一个数组的片段上构建String对象.