Guava API - FluentIterable Predicate Function Odering Range Splitter
这写API可解决的问题
1. 集合元素的过滤 - FluentIterable Predicate Range Function
1) 先说Predicate<T>,这个相当与一个过滤原则,里面有个apply()方法,通过一定的条件返回true或false,依次判断元素需不需要过滤
其中T表示待过滤集合里面的元素类型,举个例子
package guavaexam.test;
public class Man {
private String name;
private int age;
public Man(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public int getAge() {
return age;
}
public void setName(String name) {
this.name = name;
}
public void setAge(int age) {
this.age = age;
}
@Override
public String toString() {
return name + " is " + age + " years old";
}
}
package guavaexam.test;
import com.google.common.base.Predicate;
public class AgePredicate implements Predicate<Man> {
private int minAge;
public AgePredicate(int minAge) {
this.minAge = minAge;
}
@Override
public boolean apply(Man man) {
if (man.getAge() < minAge)
return false;
return true;
}
}
package guavaexam.test;
import com.google.common.base.Predicate;
public class NamePredicate implements Predicate<Man> {
private String illegalName;
public NamePredicate(String illegalName) {
this.illegalName = illegalName;
}
@Override
public boolean apply(Man man) {
if (man.getName().contains(illegalName))
return false;
return true;
}
}
此处predicate的作用是用来过滤age小于minAge的人,运用Predicates.and(predicate1, predicate2)或者Predicates.or(x,x)方法,我们可以组合多个predicate过滤器,形成一个复杂的组合条件来过滤集合元素
2) 再来说Function<E, T>,这个类主要使用来转换集合元素,其中有个apply方法,将 E 类型的元素转为 T 类型的元素返回,一般我们可以写在一个匿名类里用,例如
Iterable<Man> manIterable = FluentIterable.from(manList).filter(predicate).limit(2)
.transform(new Function<Man, Man>() {
@Override
public Man apply(Man man) {
man.setAge(man.getAge() * 2);
return man;
}
});
这个例子表示的就是将集合里的每个Man的年龄乘以2再返回
3) FluentIterable,这个类可以配合Predicate和Function对集合的每个元素进行自定义过滤,他们的配合就类似与Collections.sort()和Comparator的组合,查看如下完整的例子
package guavaexam.test; import com.google.common.base.Function;
import com.google.common.base.Predicate;
import com.google.common.base.Predicates;
import com.google.common.collect.FluentIterable;
import com.google.common.collect.ImmutableList; import java.util.List; public class FluentIterableTest {
public static void main(String[] args) {
Man man1 = new Man("Jack Miller", 18);
Man man2 = new Man("Roy Miller", 18);
Man man3 = new Man("Lily Miller", 11);
Man man4 = new Man("Rose Miller", 5);
Man man5 = new Man("Mike Chen", 34); List<Man> manList = ImmutableList.of(man1, man2, man3, man4, man5); // 组合Predicate条件
Predicate<Man> predicate = Predicates.alwaysTrue();
predicate = Predicates.and(predicate, new NamePredicate("Chen"));
predicate = Predicates.and(predicate, new AgePredicate(15)); // 使用FluentIterable过滤元素,返回一个Iterable[]
Iterable<Man> manIterable = FluentIterable.from(manList).filter(predicate).limit(2)
.transform(new Function<Man, Man>() {
@Override
public Man apply(Man man) {
man.setAge(man.getAge() * 2);
return man;
}
}); System.out.println(manIterable);
}
}
结果输出
[Jack Miller is 36 years old, Roy Miller is 36 years old]
2. 集合元素的排序
Ordering类用来构建复杂比较器,其中几个方法如下:
from(): 第一个使用的比较器,第一顺序
compound(): 第二个使用的比较器,第二顺序
onResultOf(Function func): 在两个元素比较之前,先用Function转换这个两个元素,注意是在两个元素比较之前,而不是在所有元素比较之前,下面可以看到效果
看下面的例子
package guavaexam.test.ordering;
import guavaexam.test.model.Man;
import java.util.Comparator;
public class NameComparator implements Comparator<Man> {
@Override
public int compare(Man man, Man man1) {
return man.getName().compareTo(man1.getName());
}
}
package guavaexam.test.ordering;
import guavaexam.test.model.Man;
import java.util.Comparator;
public class AgeComparator implements Comparator<Man> {
@Override
public int compare(Man man, Man man1) {
return man.getAge() > man1.getAge() ? 1 : (man.getAge() == man1.getAge() ? 0 : -1);
}
}
package guavaexam.test.ordering;
import com.google.common.base.Function;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.Lists;
import com.google.common.collect.Ordering;
import guavaexam.test.model.Man;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
public class OrderingTest {
public static void main(String[] args) {
Man man1 = new Man("Jack Miller", 18);
Man man2 = new Man("Roy Miller", 18);
Man man3 = new Man("Lily Miller", 11);
Man man4 = new Man("Rose Miller", 5);
Man man5 = new Man("Mike Chen", 34);
List<Man> manList = Lists.newArrayList(man1, man2, man3, man4, man5);
Comparator<Man> manComparator = Ordering
.from(new AgeComparator()).compound(new NameComparator())
.reverse()
.onResultOf(new Function<Man, Man>() {
@Override
public Man apply(Man man) {
man.setAge(man.getAge() * 2);
return man;
}
});
Collections.sort(manList, manComparator);
System.out.println(manList);
}
}
这个输出会非常诡异
[Roy Miller is 72 years old, Jack Miller is 144 years old, Lily Miller is 176 years old, Mike Chen is 136 years old, Rose Miller is 40 years old]
可以看到年龄并非只是 * 2,而是不可预见的被 * 2 了多次,这是因为当元素A在与元素B比较的时候就会被执行一次Function,当元素A与元素C比较时又会执行一次Function,所以最后你并不知道被执行了多少次
3. 范围判断 - Range
比较简单,不多做介绍了
package guavaexam.test.range;
import com.google.common.collect.Range;
public class RangeTest {
public static void main(String[] args) {
// 一个左开右闭的范围
Range<Integer> range = Range.openClosed(5, 10);
System.out.println(range.contains(1));
System.out.println(range.contains(6));
System.out.println(range.contains(9));
System.out.println(range.contains(10));
}
}
输出
false
true
true
true
4. Splitter 字符串切割
其常用方法有如下几个
on(String sep): 按照sep切分字符串
trimResults(): 去掉切分结果的首尾空格
omitEmptyStrings(): 忽略切分出来的空结果
withKeyValueSeparator(String sep): 根据sep在字符串切割后再切割结果变成一个map
例子如下
package guavaexam.test.splitter;
import com.google.common.base.Splitter;
import java.util.Map;
public class SplitterTest {
public static void main(String[] args) {
String s = " name $ jack?age$ 17 ? $ook ?";
Iterable<String> list = Splitter.on("?").trimResults().omitEmptyStrings().split(s);
System.out.println(list);
Map<String, String> list2 = Splitter.on("?").trimResults().omitEmptyStrings().withKeyValueSeparator("$").split(s);
System.out.println(list2);
}
}
[name $ jack, age$ 17, $ook]
{name = jack, age= 17, =ook}
Guava API - FluentIterable Predicate Function Odering Range Splitter的更多相关文章
- guava API整理
1,大纲 让我们来熟悉瓜娃,并体验下它的一些API,分成如下几个部分: Introduction Guava Collection API Guava Basic Utilities IO API C ...
- 基于Guava API实现异步通知和事件回调
本文节选自<设计模式就该这样学> 1 基于Java API实现通知机制 当小伙伴们在社区提问时,如果有设置指定用户回答,则对应的用户就会收到邮件通知,这就是观察者模式的一种应用场景.有些小 ...
- Guava之FluentIterable使用示例
FluentIterable 是guava集合类中常用的一个类,主要用于过滤.转换集合中的数据:FluentIterable是一个抽象类,实现了Iterable接口,大多数方法都返回FluentIte ...
- guava学习--FluentIterable
public class FluentIterableTest { public static void main(String[] args) { Man man1 = new Man(" ...
- Guava API
1.字符串的处理 字符串的连接&拆分&匹配及常用操作 Joiner&Splitter @Test public void testJoiner() { String[] str ...
- Guava API学习之Ordering犀利的比较器 编辑
Ordering是Guava类库提供的一个犀利强大的比较器工具,Guava的Ordering和JDK Comparator相比功能更强.它非常容易扩展,可以轻松构造复杂的comparator,然后用在 ...
- Dynamics CRM 2015/2016 Web API:Unbound Function 和 Bound Function
今天我们来看看Dynamics CRM Web API Function 吧, 这是一个新概念,刚接触的时候我也是比較的迷糊.这种命名确实是和之前的那套基于SOAP协议的API全然联系不上.好了,不说 ...
- guava(三)字符串处理 Joiner Splitter CharMatcher
一.Joiner 拼接字符串 1.join 拼接集合中的元素 System.out.println(Joiner.on(";").join(Ints.asList(1,2,3))) ...
- web dom api中的Selection和Range
如果你做过wysiwyg这样的app,一个很让人头疼的问题是如何保证执行bold,italic等格式化操作后保持先前鼠标所在的位置.要好好的解决这个问题,就必须将Selection和Range的api ...
随机推荐
- Java学习(if wihle switch for语句)
一.if语句 定义:if语句是指如果满足某种条件,就进行某种处理. 语句: if (条件语句){ 执行语句; …… } 上述格式中,判断条件是一个布尔值,当判断条件为true时,{}中的执行语句才会执 ...
- Ubuntu下Node.js开发起步之旅
因为忙其它的事,把Node.js的学习放下了快两个月了,世事变化还真快,发现很多东东都改变了,express已经升级到4.x了,变化还不小! 我原来的学习过程是在VirtualBox中安装Ubuntu ...
- 【LOJ】#2129. 「NOI2015」程序自动分析
题解 开始是想两个并查集的 和A相等,和A不相等 如果AB相等就连 A 相等,B相等 B不相等 A不相等 如果AB不相等就连 A不相等,B相等 B相等,A不相等 但是显然不对,因为和A不相等的不一定和 ...
- bzoj 1113
思路:对于两张高度一样的海报 i, j, 即 y[ i ] = y[ j ], 如果对于任意i < k < j 有y[ k ] > y[ i ] && y[ k ] ...
- Django学习笔记-2018.11.16
知识储备: 1 Python基础 2 数据库SQL 3 HTTP协议 4 HTML&&CSS 5 正则表达式 Django启动 django-admin startproject pr ...
- 基于原生JS的jsonp方法的实现
基于原生JS的jsonp方法的实现 jsonp,相信大家并不陌生,是在js异步请求中解决跨域的方法之一,原理很简单,有不清楚的同学可以google下,这里就补详细解释了.在Jquery库中,jQuer ...
- python爬虫实战(三)--------搜狗微信文章(IP代理池和用户代理池设定----scrapy)
在学习scrapy爬虫框架中,肯定会涉及到IP代理池和User-Agent池的设定,规避网站的反爬. 这两天在看一个关于搜狗微信文章爬取的视频,里面有讲到ip代理池和用户代理池,在此结合自身的所了解的 ...
- SCU 4441 Necklace
最长上升子序列,枚举. 因为$10000$最多只有$10$个,所以可以枚举采用哪一个$10000$,因为是一个环,所以每次枚举到一个$10000$,可以把这个移到最后,然后算从前往后的$LIS$和从后 ...
- heartbeat与keepalived的区别
Heartbeat与Keepalived的区别 Keepalived使用的vrrp协议方式,虚拟路由冗余协议 (Virtual Router Redundancy Protocol,简称VRRP):H ...
- Bzoj2120/洛谷P1903 数颜色(莫队)
题面 Bzoj 洛谷 题解 考虑对操作离线后分块处理询问操作(莫队算法),将询问操作按照编号分块后左端点第一关键字,右端点第二关键字排序(分块大小为\(n^{\frac 23}\)),对于每一个询问操 ...