基础工具类Joiner的使用

简介: 基础工具类Joiner的使用

Guava 中有一些基础的工具类,如下所列:


Joiner 类:根据给定的分隔符把字符串连接到一起。MapJoiner 执行相同的操作,但是针对 Map 的 key 和 value。


Splitter 类:与 Joiner 操作相反的类,是根据给定的分隔符,把一个字符串分隔成若个子字符串。


CharMatcher,Strings 类:对字符串通用的操作,例如移除字符串的某一部分,字符串匹配等等操作。


其他类:针对Object操作的方法,例如 toString 和 hashCode 方法等。


一、 Joiner


这是在我们代码中出现频率比较高的一个功能。经常需要将几个字符串,或者字符串数组、集合之类的东西,拼接成一个以指定符号分隔各个元素的字符串,比如要将一个用List保存的集合拼起来作为SQL语句的条件,在知道Joiner之前我们会这样做。

// 拼接: AND goods IN(123,1234,345)
productSql.append(" AND goods IN (");
for (Long goods : spuIdList) {
  productSql.append(goods + ",");
}
productSql.delete(productSql.length() - 1, productSql.length()).append(")");

上面的代码注意的一点就是我们要移除字符串最后的一个分隔符。虽然不难,但是很无聊,下面借助 Joiner 类,代码瞬间变得优雅起来。


productSql.append(" AND goods IN (").append(Joiner.on(",").skipNulls().join(spuIdList)).append(")");

补充:


如果传入的对象中包含空指针,会直接抛出空指针异常。Joiner 提供了两个方法,让我们能够优雅的处理待拼接集合中的空指针。


如果我们希望忽略空指针,那么可以调用 skipNulls方法,得到一个会跳过空指针的 Joiner 实例。如果希望将空指针变为某个指定的值,那么可以调用 useForNull 方法,指定用来替换空指针的字符串。


Joiner.on(",").skipNulls().join(spuIdList);
Joiner.on(",").useForNull("#").join(spuIdList);
  • Joiner 不仅可以返回string ,还有方法能够处理StringBuilder类:

二、Joiner.MapJoiner

MapJoiner 是 Joiner 的内部静态类,用于帮助将 Map 对象拼接成字符串。


@Test
public void testJoiner(){
    Map<String, String> map = new HashMap<>();
    map.put("红楼梦", "刘姥姥");
    map.put("三国演义", "关羽");
    map.put("水浒传", "李逵");
    map.put("西游记", "猪八戒");
    String str = Joiner.on(" ").withKeyValueSeparator(":").join(map);
    System.out.println(str);//水浒传:李逵 红楼梦:刘姥姥 三国演义:关羽 西游记:猪八戒
}

三、常用API总结:

appendTo

// 可追加,实现了Appendable接口的都可以使用
A appendTo(A appendable, Iterable<?> parts)
// 向appendable参数后追加first、second…所有参数
A appendTo(A appendable, @Nullable Object first, @Nullable Object second, Object… rest)

比较常见的实现类: BufferedWriter, CharArrayWriter, CharBuffer, FileWriter, FilterWriter, LogStream, Ou

tputStreamWriter, PipedWriter, PrintStream, PrintWriter, StringBuffer, StringBuilder, StringWriter, Writer

用法

String[] arr = {"a","b","c"};
StringBuilder ab = new StringBuilder("start: ");
StringBuilder ac = Joiner.on("").appendTo(ab,arr);
System.out.println(ab); // start: abc
System.out.println(ac); // start: abc

Join+on

// 将可迭代的参数中所有子元素连接。
String join(Iterable<?> parts)
// 为static对象设置分隔符
static Joiner on(char separator)


Joiner实例不可变,即用final修饰,一旦初始化不可变,所以分步调用joiner的静态函数是不起作用的。如:

@Test
public void testJoiner(){
    Joiner joiner = Joiner.on(',');
    joiner.skipNulls(); // 不起作用!
    String str = joiner.join("wrong", null, "wrong");
    System.out.println(str);
}
// 会抛出 NullPointerException

这样使得joiner线程安全,并且返回的都是final static常量

其他

Joiner skipNulls()
Joiner useForNull(String nullText)
Joiner.MapJoiner withKeyValueSeparator(String keyValueSeparator)

最后


大家有兴趣的可以去了解下Guava中其他类的用法,源码写的也很棒!


附上链接:


Joinner源码解析:https://blog.csdn.net/dancheng1/article/details/84819034


强大的Google Guava类库: https://cloud.tencent.com/developer/article/2035964


Guava库使用:https://blog.csdn.net/weixin_44139651/article/details/123804181


效率提升神器之Guava-Joiner:https://baijiahao.baidu.com/s?id=1736921815066348757&wfr=spider&for=pc


相关文章
|
24天前
|
存储 算法 安全
加密和解密函数应用到Pinia状态管理的具体步骤是什么?
加密和解密函数应用到Pinia状态管理的具体步骤是什么?
293 159
|
前端开发
Promise.allSettled()和Promise.all()在处理错误时的差异是什么?
Promise.allSettled()和Promise.all()在处理错误时的差异是什么?
590 170
|
存储 监控 Oracle
《MySQL高级篇》一、MySQL的目录结构
《MySQL高级篇》一、MySQL的目录结构
1211 157
《MySQL高级篇》一、MySQL的目录结构
|
存储 负载均衡 NoSQL
《Redis实战篇》一、短信登录
《Redis实战篇》一、短信登录
523 156
《Redis实战篇》一、短信登录
|
设计模式 JSON 算法
公司来了个京东T6,只用两个工具类教会了我如何进行数据对比
公司来了个京东T6,只用两个工具类教会了我如何进行数据对比
558 156
|
SQL 负载均衡 前端开发
基于Patroni的Citus高可用环境部署
Citus是一个非常实用的能够使PostgreSQL具有进行水平扩展能力的插件,或者说是一款以PostgreSQL插件形式部署的基于PostgreSQL的分布式HTAP数据库。本文简单说明Citus的高可用技术方案,并实际演示基于Patroni搭建Citus HA环境的步骤。
3250 154
|
SQL 存储 关系型数据库
Citus 多CN部署与Citus MX
Citus MX是Citus集群中横向扩展CN能力的技术,本文件聊一下Citus MX使用的话题
2900 140
|
SQL 存储 关系型数据库
pg_rewind实现原理简单分析
pg_rewind的功能是在主备切换后回退旧主库上多余的事务变更,以便可以作为新主的备机和新主建立复制关系。本文简单介绍其实现原理。
2410 145
|
NoSQL Redis
RedisConf19会议记录 Day0: Training
# 前言 2019年的RedisConf比以往时候来的更早一些,今年会议时间是4月1-3号,仍然是在旧金山鱼人码头Pier 27。恰逢今年是Redis第10周年,规模也比以往大一些,注册人数超过1600人,总共有80个议题,除了RedisLabs外还有很多云厂商和Redis用户带来分享,今年也是阿里云首次在RedisConf进行分享。 # Agenda 会议总共三天,第一天是Tr
1731 156
|
SQL 关系型数据库 MySQL