guava之Joiner 和 Splitter
2016-07-16 09:12
323 查看
本文将记录Guava中得字符串处理Joiner(连接)和Splitter(分割)处理。
转载:http://www.cnblogs.com/whitewolf/p/4214749.html
首先我们来看看下面我们经常遇见的一个案例:
如果不用第三方库,如common-lange,Guava,用原生java,我们将怎么继续?
是不是很简单,但是繁琐,而且这里还有个坑,我们使用append的方式,在每次for完成后,我们必须去修正remove最后的分隔符:builder.setLength(builder.length() delimiter.length());
Guava版本呢?
我们不在考虑更多的细节,并且很有语义的告诉代码的阅读者,用什么分隔符,需要过滤null值再join。
note:当然我们也可以用common-lange来很简单的完成:StringUtils.join(stringList, delimiter).但是个人推荐尽量使用Guava替代common-lange,因为Guava还有更多的有用方法,后续会陆续介绍,还有就是Guava的API相对更有语意一点。
对于MapJoinner和MapSplitter的最好案例就是url的param编码。
利用Guava的MapJoinner的代码如下:
这里采用了on传入map item之间分隔符,以及withKeyValueSeparator传递map项key/value之间的分隔符。所以能够很简单的实现,不用我们在去实现一个的for循环代码。
利用Guava的MapSplitter的代码如下:
这里同样利用on传入字符串的第一分隔符,withKeyValueSeparator传入项的分隔符,产生map的key/value项,其结果是一个{id=123, name=green}的Map对象。
转载:http://www.cnblogs.com/whitewolf/p/4214749.html
Joiner
首先我们来看看下面我们经常遇见的一个案例:题目: 对于一个如下定义List List<String> list = new ArrayList<String>("1", "2", null, “3”); 按照’,’分割,并过滤掉null。
如果不用第三方库,如common-lange,Guava,用原生java,我们将怎么继续?
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 | public static String join(List stringList, String delimiter) { StringBuilder builder = new StringBuilder(); for (Object item : stringList) { if (item != null) { builder .append(item) .append(delimiter); } } builder.setLength(builder.length() delimiter.length()); return builder.toString(); } |
Guava版本呢?
1 2 3 4 5 6 | public static String joinByGuava(List stringList, String delimiter) { return Joiner .on(delimiter) .skipNulls() .join(stringList); } |
note:当然我们也可以用common-lange来很简单的完成:StringUtils.join(stringList, delimiter).但是个人推荐尽量使用Guava替代common-lange,因为Guava还有更多的有用方法,后续会陆续介绍,还有就是Guava的API相对更有语意一点。
Splitter
MapJoinner和MapSplitter
对于MapJoinner和MapSplitter的最好案例就是url的param编码。
MapJoinner
题目: 生产一个查询id: 123,name: green的学生信息的url。
利用Guava的MapJoinner的代码如下:
1 | Joiner.on("&").withKeyValueSeparator("=").join(ImmutableMap.of("id", "123", "name", "green")); |
MapSplitter
题目: 对url中的查询字符串"id=123&name=green"进行分割
利用Guava的MapSplitter的代码如下:
1 | final Map<String, String> join = Splitter.on("&").withKeyValueSeparator("=").split("id=123&name=green"); |
相关文章推荐
- AsyncTask工具类的使用-真实下载图片实例
- 【转】8G内存下MySQL的优化详细方案
- Oracle OCP笔记(31)使用闪回功能
- MySQL server has gone away报错原因分析
- 收集座右铭
- 《剑指offer》-把字符串转换成整数
- mysql 主从复制配置
- C++体会
- MySQL show processlist命令详解
- Oracle OCP笔记(30)数据库恢复
- ubuntu14 启用中文输入法
- 操作系统思考 第八章 多任务
- 1、转换 2、过渡 3、动画
- Oracle OCP笔记(29)RMAN备份 - Config
- linux编译软件
- PHP数组函数: array_walk()与 array_map() 的区别
- eclise项目中文转码
- KMP模板
- 正则表达式表单验证
- hdu 1423(最长公共上升子序列)