使用Java 8的更新版本(原始版本在文章末尾)
如果您不需要过滤任何可以使用的元素
从Java 8开始,我们可以使用(而不是最初使用)并简化我们的代码。
此外,为了避免在每次调用中重新编译正则表达式,我们可以创建单独的Pattern,它将在其编译版本保存在某个字段中,并在需要时使用它。StringJoiner
StringBulder
" *"
matches(" *")
private static final Pattern SPACES_OR_EMPTY = Pattern.compile(" *");
public static String implode(String separator, String... data) {
StringJoiner sb = new StringJoiner(separator);
for (String token : data) {
if (!SPACES_OR_EMPTY.matcher(token).matches()) {
sb.add(token);
}
}
return sb.toString();
}
对于流,我们的代码可以看起来像这样。
private static final Predicate<String> IS_NOT_SPACES_ONLY =
Pattern.compile("^\\s*$").asPredicate().negate();
public static String implode(String delimiter, String... data) {
return Arrays.stream(data)
.filter(IS_NOT_SPACES_ONLY)
.collect(Collectors.joining(delimiter));
}
如果我们使用流,我们可以元素.在这种情况下,我们希望谓词接受不仅仅是空格的字符串 - 换句话说,字符串必须包含非空格字符。filter
Predicate
我们可以从模式创建这样的谓词。以这种方式创建的谓词将接受任何包含可由正则表达式匹配的子字符串的字符串(因此,如果正则表达式将查找谓词,则将接受诸如 , , , 的字符串,但不会接受或 )。"\\S"
"foo "
" foo bar "
"whatever"
" "
" "
所以我们可以使用
Pattern.compile("\\S").asPredicate();
或者可能更具描述性,否定只有空格或空的字符串
Pattern.compile("^\\s*$").asPredicate().negate();
接下来,当过滤器将删除所有空的,或仅包含空格的字符串我们可以休息的元素。多亏了我们可以决定使用哪个分隔符。collect
Collectors.joining
原始答案(在 Java 8 之前)
public static String implode(String separator, String... data) {
StringBuilder sb = new StringBuilder();
for (int i = 0; i < data.length - 1; i++) {
//data.length - 1 => to not add separator at the end
if (!data[i].matches(" *")) {//empty string are ""; " "; " "; and so on
sb.append(data[i]);
sb.append(separator);
}
}
sb.append(data[data.length - 1].trim());
return sb.toString();
}
你可以像这样使用它
System.out.println(implode(", ", "ab", " ", "abs"));
或
System.out.println(implode(", ", new String[] { "ab", " ", "abs" }));
输出ab, abs