Java 8 StringJoiner,优雅拼接,问句长尾,一问成诗。

2026-04-19 14:421阅读0评论SEO基础
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计598个文字,预计阅读时间需要3分钟。

Java 8 StringJoiner,优雅拼接,问句长尾,一问成诗。

`StringJoiner` 是 Java8 新增的用于处理字符串拼接的工具类,可以使代码更优雅、不易出错。例如,假设要遍历一个字符串集合,每个元素后都跟一个 `.` 分隔符,可以使用以下代码实现:

javaString a=w, b=d, c=c;StringJoiner joiner=new StringJoiner(.);

joiner.add(a).add(b).add(c);

System.out.println(joiner.toString());

输出结果为:

w.d.c

StringJoiner是Java8新出的用于处理字符串拼接的工具类,可以让你的代码看起来更优雅,不拉跨。

假设现在遍历一个字符串集合,需求是每个元素按照 “.” 分开。

Java 8 StringJoiner,优雅拼接,问句长尾,一问成诗。

String a = "w", b = "d", c = "n", d = "m", e = "d"; List<String> list = new ArrayList<>(); list.add(a); list.add(b); list.add(c); list.add(d); list.add(e);

最原始的做法,拼接就完了,eazy。

String result = ""; for (String str : list) { result += str + "."; } // 最后在处理掉最后一个 “.” 齐活儿,收工 System.err.println(result.substring(0, result.length() - 1));

emm 有点丑,优雅点!

StringBuilder builder = new StringBuilder(); list.forEach(str -> builder.append(str).append(".")); System.err.println(builder.toString().substring(0, builder.length() - 1));

上面的都不太方便,还要处理下结果,怪麻烦的,那能不能更优雅呢?能!上StringJoiner!

// 声明StringJoiner, 每个元素通过 "." 分割 StringJoiner joiner = new StringJoiner("."); list.forEach(joiner::add); System.err.println(joiner.toString());

达到了一样的效果

那还有啥其他作用不?

// 每个元素通过 "." 分割,并且用 "[" 和 "]" 包住前后 StringJoiner joiner2 = new StringJoiner(".", "[", "]"); list.forEach(joiner2::add); System.err.println(joiner2.toString());

再比如

// 每个元素通过 "." 分割,并且用 "[" 和 "]" 包住前后 StringJoiner joiner2 = new StringJoiner(".", "[", "]"); list.forEach(joiner2::add); // 将joner和joner2的元素合并,并且每个元素通过 "." 分割,并且用 "[" 和 "]" 包住前后 joiner2.merge(joiner); System.err.println(joiner2.toString());

这还有个setEmptyValue,看方法名字是设置个空值?试一下,发现并没啥效果,点进去瞅瞅。

StringJoiner joiner = new StringJoiner("."); list.forEach(joiner::add); System.err.println(joiner.toString()); joiner.setEmptyValue("abc"); System.err.println(joiner.toString());



奥,意思是如果啥都没有的时候就在toString和length返回这个emptyValue的值/长度呗,emm,没想到具体有啥用 🙃

总结

到此这篇关于Java8优雅的字符串拼接工具类StringJoiner的文章就介绍到这了,更多相关Java8字符串拼接StringJoiner内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!

本文共计598个文字,预计阅读时间需要3分钟。

Java 8 StringJoiner,优雅拼接,问句长尾,一问成诗。

`StringJoiner` 是 Java8 新增的用于处理字符串拼接的工具类,可以使代码更优雅、不易出错。例如,假设要遍历一个字符串集合,每个元素后都跟一个 `.` 分隔符,可以使用以下代码实现:

javaString a=w, b=d, c=c;StringJoiner joiner=new StringJoiner(.);

joiner.add(a).add(b).add(c);

System.out.println(joiner.toString());

输出结果为:

w.d.c

StringJoiner是Java8新出的用于处理字符串拼接的工具类,可以让你的代码看起来更优雅,不拉跨。

假设现在遍历一个字符串集合,需求是每个元素按照 “.” 分开。

Java 8 StringJoiner,优雅拼接,问句长尾,一问成诗。

String a = "w", b = "d", c = "n", d = "m", e = "d"; List<String> list = new ArrayList<>(); list.add(a); list.add(b); list.add(c); list.add(d); list.add(e);

最原始的做法,拼接就完了,eazy。

String result = ""; for (String str : list) { result += str + "."; } // 最后在处理掉最后一个 “.” 齐活儿,收工 System.err.println(result.substring(0, result.length() - 1));

emm 有点丑,优雅点!

StringBuilder builder = new StringBuilder(); list.forEach(str -> builder.append(str).append(".")); System.err.println(builder.toString().substring(0, builder.length() - 1));

上面的都不太方便,还要处理下结果,怪麻烦的,那能不能更优雅呢?能!上StringJoiner!

// 声明StringJoiner, 每个元素通过 "." 分割 StringJoiner joiner = new StringJoiner("."); list.forEach(joiner::add); System.err.println(joiner.toString());

达到了一样的效果

那还有啥其他作用不?

// 每个元素通过 "." 分割,并且用 "[" 和 "]" 包住前后 StringJoiner joiner2 = new StringJoiner(".", "[", "]"); list.forEach(joiner2::add); System.err.println(joiner2.toString());

再比如

// 每个元素通过 "." 分割,并且用 "[" 和 "]" 包住前后 StringJoiner joiner2 = new StringJoiner(".", "[", "]"); list.forEach(joiner2::add); // 将joner和joner2的元素合并,并且每个元素通过 "." 分割,并且用 "[" 和 "]" 包住前后 joiner2.merge(joiner); System.err.println(joiner2.toString());

这还有个setEmptyValue,看方法名字是设置个空值?试一下,发现并没啥效果,点进去瞅瞅。

StringJoiner joiner = new StringJoiner("."); list.forEach(joiner::add); System.err.println(joiner.toString()); joiner.setEmptyValue("abc"); System.err.println(joiner.toString());



奥,意思是如果啥都没有的时候就在toString和length返回这个emptyValue的值/长度呗,emm,没想到具体有啥用 🙃

总结

到此这篇关于Java8优雅的字符串拼接工具类StringJoiner的文章就介绍到这了,更多相关Java8字符串拼接StringJoiner内容请搜索易盾网络以前的文章或继续浏览下面的相关文章希望大家以后多多支持易盾网络!