[b]建议:[/b]
(1)如果要用正则表达式作为分隔符来拆分字符串,则必须使用string.split(string regexp)来处理;
(2)如果用普通的字符或字串来拆分字符串,则可以选择使用stringtokenizer来处理,但使用string.split(string)将更好。
因为string.split(string regexp)的实质是pattern.compile(regex).split(this, limit),而pattern.compile(regex)花费的代价是很大的。如果多次要调用同一个pattern对象,则可以先预编译好pattern,然后反复使用该pattern对象。比如:
可以改为:
这样就可以避免在循环中多次编译构建pattern对象。
(1)如果要用正则表达式作为分隔符来拆分字符串,则必须使用string.split(string regexp)来处理;
(2)如果用普通的字符或字串来拆分字符串,则可以选择使用stringtokenizer来处理,但使用string.split(string)将更好。
/** * <tt>stringtokenizer</tt> is a legacy class that is retained for * compatibility reasons although its use is discouraged in new code. it is * recommended that anyone seeking this functionality use the <tt>split</tt> * method of <tt>string</tt> or the java.util.regex package instead.**/翻译后:stringtokenizer是一个历史遗留的类,尽管不鼓励在新代码中使用,但因为兼容性的原因还是被保留下来了。推荐大家在string类的split方法或java.util.regex包中寻找这个功能来替代。因为string.split(string regexp)的实质是pattern.compile(regex).split(this, limit),而pattern.compile(regex)花费的代价是很大的。如果多次要调用同一个pattern对象,则可以先预编译好pattern,然后反复使用该pattern对象。比如:
for (string v: strlist) { v.split("a*b");}可以改为:
pattern p = pattern.compile("a*b");for (string v:strlist) { p.split(v,0)'}这样就可以避免在循环中多次编译构建pattern对象。
本文介绍了在Java中使用string.split和stringtokenizer进行字符串拆分的方法。推荐使用string.split以提高效率,尤其是在处理正则表达式时。同时,对于需要频繁使用的模式,建议预编译Pattern对象以减少重复编译的成本。
7793

被折叠的 条评论
为什么被折叠?



