public class StringTokenizer {
private static final String DEFAULT_SEPARATORS = " \t\r\n";
private Enumeration i;
public StringTokenizer(final String source, final String separators) {
parse(source != null ? source.toCharArray() : null, separators);
}
public StringTokenizer(final char[] source, final String separators) {
parse(source, separators);
}
public StringTokenizer(final String source) {
parse(source != null ? source.toCharArray() : null, DEFAULT_SEPARATORS);
}
public StringTokenizer(final char[] source) {
parse(source, DEFAULT_SEPARATORS);
}
private void parse(final char[] source, final String separators) {
if (source == null) {
i = new Vector().elements();
} else {
final String seps = separators != null ? separators :
DEFAULT_SEPARATORS;
final Vector tokens = new Vector(10);
final StringBuffer token = new StringBuffer();
final int length = source.length;
for (int index = 0; index < length; index++) {
if (seps.indexOf(source[index]) > -1) {
tokens.addElement(token.toString());
token.delete(0, token.length());
} else {
token.append(source[index]);
}
}
if (token.length() > 0) {
tokens.addElement(token.toString());
}
i = tokens.elements();
}
}
public boolean hasMoreTokens() {
return i.hasMoreElements();
}
public String nextToken() {
return (String) i.nextElement();
}
}
StringTokenizer
最新推荐文章于 2024-06-28 10:37:00 发布
本文介绍了一个自定义的字符串解析器类,该类能够根据指定的分隔符将输入的字符串拆分成多个部分,并提供了迭代这些部分的功能。解析器支持自定义分隔符,能够灵活应用于不同的字符串处理场景。
844

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



