Function用于同步转换。

Predicate用于过滤。

import java.util.Collection;

import java.util.Iterator;

import java.util.List;

import java.util.Map;

import com.google.common.base.Function;

import com.google.common.base.Functions;

import com.google.common.base.Objects;

import com.google.common.base.Predicate;

import com.google.common.collect.Collections2;

import com.google.common.collect.Iterators;

import com.google.common.collect.Lists;

import com.google.common.collect.Maps;

public class User {

private String username;

private String sex;

public User(String username, String sex) {

this.username = username;

this.sex = sex;

}

void setUsername(String username) {

this.username = username;

}

void setSex(String sex) {

this.sex = sex;

}

String getUsername() {

return username;

}

String getSex() {

return sex;

}

@Override

public String toString() {

return Objects.toStringHelper(this).omitNullValues().add("username", username).add("sex", sex).toString();

}

public static void main(String[] args) {

User u1 = new User("malone", "man");

User u2 = new User("lanlan", "woman");

List<User> list = Lists.newArrayList(u1, u2);

// Function 这里用于类型转换

Collection<String> result = Collections2.transform(list, new Function<User, String>() {

@Override

public String apply(User user) {

if (Objects.equal(user, null)) {

return "";

}

return user.toString();

}

});

for (String ss : result) {

System.out.println(ss);

}

// Predicate 这里是用于过滤

Collection<User> resultUser = Collections2.filter(list, new Predicate<User>() {

@Override

public boolean apply(User user) {

if (Objects.equal(user, null)) {

return false;

}

if (Objects.equal(user.getSex(), "woman")) {

return false;

}

return true;

}

});

for (User ss : resultUser) {

System.out.println(ss);

}

Function<User, String> f1 = new Function<User, String>() {

@Override

public String apply(User user) {

if (Objects.equal(user, null)) {

return "";

}

return user.getUsername();

}

};

// 多个工具类均可使用类函数式编程

Collection<String> result1 = Collections2.transform(list, f1);

for (String ss : result1) {

System.out.println("1:" + ss);

}

List<String> strList = Lists.transform(list, f1);

for (String ss : strList) {

System.out.println("2:" + ss);

}

Iterator<String> it = Iterators.transform(list.iterator(), f1);

while (it.hasNext()) {

System.out.println("3:" + it.next());

}

Function<String, String> f2 = new Function<String, String>() {

@Override

public String apply(String input) {

if (Objects.equal(input, "malone")) {

return "malone's function";

} else {

return "lanlan's function";

}

}

};

// 连接多个Function

// Warning:这里compose方法的参数位置不能颠倒,

//        * Function<A, C> compose(Function<B, C> g, Function<A, ? extends B> f)

//        * 传入Function<B,C>、Function<A, ? extends B>组合成Function<A, C>

Function<User, String> f3 = Functions.compose(f2, f1);

List<String> mylist = Lists.transform(list, f3);

System.out.println(mylist.get(0));

Map<String, String> map = Maps.newHashMap();

map.put("1", "2");

// Functions可以转换一下map,使用语义更直白的代码,并提供默认值支持

Function<String, String> lookup = Functions.forMap(map, "default value");

System.out.println(lookup.apply("1"));

}

}

Predicates:

Map<String, Girl> map = new HashMap<String, Girl>() {
{
put("love the age", new Girl(18, "not so nice"));
put("love the face", new Girl(16, "so nice"));
}
};
Function<String, Girl> function = Functions.forMap(map);
Predicate<Girl> predicate = new Predicate<Girl>() {
@Override
public boolean apply(Girl input) {
return input.getAge() >= 18;
}
};
Predicate<String> result = Predicates.compose(predicate, function);
return result;

guava学习--Function、Predicate的更多相关文章

  1. guava 学习笔记(二) 瓜娃(guava)的API快速熟悉使用

    guava 学习笔记(二) 瓜娃(guava)的API快速熟悉使用 1,大纲 让我们来熟悉瓜娃,并体验下它的一些API,分成如下几个部分: Introduction Guava Collection ...

  2. Function, Predicate

    Function, Predicate的使用 Function用于把一种类型的对象转化为另一种类型的对象.Predicate用于判断某个对象是否符合一定条件. 一.Function和Functions ...

  3. [置顶] Guava学习之Lists

    Lists类主要提供了对List类的子类构造以及操作的静态方法.在Lists类中支持构造ArrayList.LinkedList以及newCopyOnWriteArrayList对象的方法.其中提供了 ...

  4. Guava学习笔记目录

    Guava 是一个 Google 的基于java1.6的类库集合的扩展项目,包括 collections, caching, primitives support, concurrency libra ...

  5. guava 学习笔记 使用瓜娃(guava)的选择和预判断使代码变得简洁

    guava 学习笔记 使用瓜娃(guava)的选择和预判断使代码变得简洁 1,本文翻译自 http://eclipsesource.com/blogs/2012/06/06/cleaner-code- ...

  6. Guava学习

    Guava学习笔记目录 Guava 是一个 Google 的基于java1.6的类库集合的扩展项目,包括 collections, caching, primitives support, concu ...

  7. [置顶] Guava学习之ArrayListMultimap

    ArrayListMultimap类的继承关系如下图所示: Guava ArrayListMultimap List Multimap 是一个接口,继承自 Multimap 接口.ListMultim ...

  8. [置顶] Guava学习之Splitter

    Splitter:在Guava官方的解释为:Extracts non-overlapping substrings from an input string, typically by recogni ...

  9. [置顶] Guava学习之Iterators

    Iterators类提供了返回Iterator类型的对象或者对Iterator类型对象操作的方法.除了特别的说明,Iterators类中所有的方法都在Iterables类中有相应的基于Iterable ...

随机推荐

  1. openGL 环境配置

    1.(glfw) 参考地址:http://www.cnblogs.com/be2n2me/p/3701338.html 在Mac OS X EI Capitan上sudo make install时遇 ...

  2. 某预约系统分析 > 某区公共自行车租车卡在线预约,关于如何提高成功概率

    概诉 网上提交预约申请单,线下面交完成实体卡的交付和办理. 本文主要从技术角度分析预约页面,仅供初学者技术交流使用. 表单输入和校验 系统通过2步的确认点击到达信息输入页面. 地址:/bjggzxc/ ...

  3. [poj2182] Lost Cows (线段树)

    线段树 Description N (2 <= N <= 8,000) cows have unique brands in the range 1..N. In a spectacula ...

  4. js跳转

    window.location.reload(); //刷新当前页,参数保留

  5. hihoCoder 1425 : What a Beautiful Lake(美丽滴湖)

    hihoCoder #1425 : What a Beautiful Lake(美丽滴湖) 时间限制:1000ms 单点时限:1000ms 内存限制:256MB Description - 题目描述 ...

  6. Reactor事件驱动的两种设计实现:面向对象 VS 函数式编程

    Reactor事件驱动的两种设计实现:面向对象 VS 函数式编程 这里的函数式编程的设计以muduo为例进行对比说明: Reactor实现架构对比 面向对象的设计类图如下: 函数式编程以muduo为例 ...

  7. URL编码和解码工具

    开发中发现需要进行URL的编解码,每次百度出来的还带广告而且比较慢,写了一个本地的工具,比较简单,希望对大家有帮助. <!DOCTYPE html PUBLIC "-//W3C//DT ...

  8. linux应用程序开发-进程通信(IPC)

    IPC why: 1.数据传输 2.资源共享 目的: 3.通知事件 4.进程控制 发展: 1.UNIX进程间通信 2.基于SYStem V 3.POSIX 方式分类: 1.pipe(管道) FIFO( ...

  9. Android手机_软件01

    1.微信 下载:http://weixin.qq.com/ 2.QQ 下载:http://im.qq.com/download/ 3.滴滴打车(乘客端):http://www.xiaojukeji.c ...

  10. 说说focus /focusin /focusout /blur 事件

    事件触发时间 focus:当focusable元素获得焦点时,不支持冒泡:focusin:和focus一样,只是此事件支持冒泡:blur:当focusable元素失去焦点时,不支持冒泡:focusou ...