前言
字符串拼接不管是在业务上,还是写算法时都会频繁使用到。
相信没有小伙伴没有写过这样的代码,比如说现在让我们来实现一个字符串拼接的场景,怎样的实现才算是优雅的呢?
以将int数组转为英文逗号分隔的字符串为例进行演示
String底层原理
在讨论字符串拼接时,首先需要知道String的底层原理。
看下结构
private final byte[] value;
这一行代码已经可以说明很多东西。字符串实质就是不可变的byte数组。因为不可变,所以对他进行拼接对他拼接实际就是生成了多个对象,这就是不鼓励对字符串进行拼接的原因。但不可变也有很多好处,例如线程安全、可以存在字符串缓冲池复用字符串等。
1. 普通写法
直接使用StringBuilder来拼接
public String join(Listlist) { StringBuilder builder = new StringBuilder(); for(Integer sub: list) { builder.append(sub).append(","); } return builder.substring(0, builder.length() - 1); }
上面这种写法相信比较常见,相对来说不太顺眼的地方就是最后的toString,需要将最后的一个英文逗号给干掉
当然也可以用下面这种事前判断方式,避免最终的字符串截取
public String join2(Listlist) { StringBuilder builder = new StringBuilder(); boolean first = true; for (Integer sub: list) { if (first) { first = false; } else { builder.append(","); } builder.append(sub); } return builder.toString(); }
2. StringJoiner
上面实现中,干掉最后的一个分隔符实在不是很优雅,那么有更好一点的用法么,接下来看一下使用StringJoiner的方式
public String join3(Listlist) { StringJoiner joiner = new StringJoiner(","); for (Integer s : list) { joiner.add(String.valueOf(s)); } return joiner.toString(); }
StringJoiner由jdk1.8提供,除了上面的基础玩法之外,结合jdk1.8带来的流操作方式,可以更简洁的实现
return list.stream().map(String::valueOf).collect(Collectors.joining(","));
怎么样,上面这个实现比起前面的代码是不是要简洁多了,一行代码完事
3. guava joiner
如果使用的jdk还不是1.8版本,不能使用上面的StringJoiner,没关系,还有guava的Joiner也可以实现
public String join5(Listlist) { return Joiner.on(",").join(list); }
注意
接收的参数类型为: 数组/Iterable/Iterator/可变参数, 基本上可以覆盖我们日常的业务场景
4. 小结
本篇文章的主题是一个非常非常常见的字符串拼接,一般来讲,我们在做字符串拼接时,最麻烦的事情就是分隔符的处理,要么就是分隔符前置添加,每次循环都需要判断是否为开头;要么就是后置,最后取字符串时,干掉最后一个分隔符
本文提供了一个非常使用的方式StringJoiner,完全解决了上面的分隔符问题,它的使用有两种场景
- 简单的容器转String:直接借助Stream的Collectors.joining来实现
- for循环 (这种场景一般是for循环内的逻辑不仅仅包括字符串拼接,还包括其他的业务逻辑): 循环内直接执行stringJoiner.add()添加
对于jdk1.8及以上的版本,优先推荐使用上面说的StringJoiner来实现
总结
到此这篇关于java实战小技巧之优雅实现字符串拼接的文章就介绍到这了,更多相关java字符串拼接内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!