guava(二) Equivalence & Supplier
一、Equivalence
一种判定两个实例是否相等的策略
全路径:
com.google.common.base
声明:
@GwtCompatible
public abstract class Equivalence<T>
核心方法
equivalent()
public final boolean equivalent(@Nullable T a, @Nullable T b) {
if (a == b) {
return true;
}
if (a == null || b == null) {
return false;
}
return doEquivalent(a, b);
}
Equivalence<F> onResultOf(Function<F, ? extends T> function) 先计算funcion,在比较
boolean result = Equivalence.equals().onResultOf(new Function<Object, Object>() {
@Override
public Object apply(Object input) {
return null;
}
}).equivalent(1, 2);
Predicate<T> equivalentTo(@Nullable T target) 转成predicate
Map<String,Integer> result=Maps.filterKeys(ImmutableMap.of("a",1,"b",2),Equivalence.equals().equivalentTo("a"));
静态内部类 Equals(如其名,判断内容是否相等)
声明:
static final class Equals extends Equivalence<Object> implements Serializable
重写 doEquivalent
@Override
protected boolean doEquivalent(Object a, Object b) {
return a.equals(b);
}
获得Equals实例
Equivalence.equals()
举个例子
String s="abc";
String s1=new String("abc");
System.out.println(Equivalence.equals().equivalent(s,s1));//true
静态内部类 Identity (如其名,判断内存地址是否唯一)
声明:
static final class Identity extends Equivalence<Object> implements Serializable
重写 doEquivalent
@Override
protected boolean doEquivalent(Object a, Object b) {
return false;
}
获得Equals实例
Equivalence.identity()
举个例子
String s="abc";
String s1=new String("abc");
System.out.println(Equivalence.identity().equivalent(s,s1)); //false
子类 FunctionalEquivalence
声明:
final class FunctionalEquivalence<F, T> extends Equivalence<F> implements Serializabl
构造函数:
FunctionalEquivalence(Function<F, ? extends T> function, Equivalence<T> resultEquivalence) {
this.function = checkNotNull(function);
this.resultEquivalence = checkNotNull(resultEquivalence);
}
重写 doEquivalent
@Override
protected boolean doEquivalent(F a, F b) {
return resultEquivalence.equivalent(function.apply(a), function.apply(b));
}
举个例子
看起来是经过function处理后,判断相等关系。default修饰符,暂时没看懂怎么使用 - -
子类 PairwiseEquivalence
声明:
final class PairwiseEquivalence<T> extends Equivalence<Iterable<T>> implements Serializable
构造函数
PairwiseEquivalence(Equivalence<? super T> elementEquivalence) {
this.elementEquivalence = Preconditions.checkNotNull(elementEquivalence);
}
重写 doEquivalent
@Override
protected boolean doEquivalent(Iterable<T> iterableA, Iterable<T> iterableB) {
Iterator<T> iteratorA = iterableA.iterator();
Iterator<T> iteratorB = iterableB.iterator(); while (iteratorA.hasNext() && iteratorB.hasNext()) {
if (!elementEquivalence.equivalent(iteratorA.next(), iteratorB.next())) {
return false;
}
} return !iteratorA.hasNext() && !iteratorB.hasNext();
}
举个例子
看起来是传入一种相等策略,判断两个集合中的元素是否完全相等,default修饰,暂时没看懂怎么使用
二、Supplier
惰性求值。我们可以把耗资源运算放到get方法里,在程序里,我们传递的是Supplier对象,直到调用get方法时,运算才会执行。
全路径:
com.google.common.base
定义
public interface Supplier<T> {
@CanIgnoreReturnValue
T get();
}
举个例子
Supplier<Integer> supplier = new Supplier<Integer>() {
@Override
public Integer get() {
return 2;
}
};
int result=supplier.get();
Suppliers
工具类,提供一些静态方法,生成一些特殊的Supplier
Supplier<T> memoize(Supplier<T> delegate) 返回一个只计算一次的supplier
Supplier supplier1= Suppliers.memoize(new Supplier<Object>() {
@Override
public Object get() {
return null;
}
});
Supplier<T> memoizeWithExpiration(Supplier<T> delegate, long duration, TimeUnit unit) 返回一个超时的supplier,超时后会重新计算
Supplier supplier1= Suppliers.memoizeWithExpiration((new Supplier<Object>() {
@Override
public Object get() {
return null;
}
}),2,TimeUnit.HOURS);
Supplier<T> ofInstance(@Nullable T instance) 常量
Supplier supplier= Suppliers.ofInstance(2);
Supplier<T> compose(Function<? super F, T> function, Supplier<F> supplier) 先计算supplier,再计算funciton
Supplier supplier= Suppliers.compose(new Function<Object, Object>() {
@Override
public Object apply(Object input) {
System.out.println("aaaaaa");
return null;
}
}, new Supplier<Object>() {
@Override
public Object get() {
System.out.println("bbbbbbb");
return null;
}
});
Supplier<T> synchronizedSupplier(Supplier<T> delegate) 线程安全
Supplier supplier= Suppliers.synchronizedSupplier(new Supplier() {
@Override
public Object get() {
return null;
}
});
guava(二) Equivalence & Supplier的更多相关文章
- Guava cacha 机制及源码分析
1.ehcahce 什么时候用比较好:2.问题:当有个消息的key不在guava里面的话,如果大量的消息过来,会同时请求数据库吗?还是只有一个请求数据库,其他的等待第一个把数据从DB加载到Guava中 ...
- java8新特性——四大内置核心函数式接口
在前面几篇简单介绍了一些Lambda表达式得好处与语法,我们知道使用Lambda表达式是需要使用函数式接口得,那么,岂不是在我们开发过程中需要定义许多函数式接口,其实不然,java8其实已经为我们定义 ...
- Java8的新特性--函数式接口
目录 函数式接口 什么是函数式接口 函数式接口的使用 Java8内置的四大核心函数式接口 一.Consumer:消费型接口(void accept(T t)) 二.Supplier:供给型接口(T g ...
- Guava Supplier实例
今天想讲一下Guava Suppliers的几点用法.Guava Suppliers的主要功能是创建包裹的单例对象,通过get方法可以获取对象的值.每次获取的对象都为同一个对象,但你和单例模式有所区别 ...
- guava 学习笔记(二) 瓜娃(guava)的API快速熟悉使用
guava 学习笔记(二) 瓜娃(guava)的API快速熟悉使用 1,大纲 让我们来熟悉瓜娃,并体验下它的一些API,分成如下几个部分: Introduction Guava Collection ...
- guava学习--Supplier Suppliers
转载:http://www.cnblogs.com/jun-ma/p/4850591.html Guava Suppliers的主要功能是创建包裹的单例对象,通过get方法可以获取对象的值.每次获取的 ...
- Spring Boot 揭秘与实战(二) 数据缓存篇 - Guava Cache
文章目录 1. Guava Cache 集成 2. 个性化配置 3. 源代码 本文,讲解 Spring Boot 如何集成 Guava Cache,实现缓存. 在阅读「Spring Boot 揭秘与实 ...
- Guava的Supplier实现单例
1.函数式编程: 2.第一次get时才会初始化: 3.可以实现单例或缓存. package suppliers; import com.google.common.base.Supplier; imp ...
- guava快速入门(二)
Guava工程包含了若干被Google的 Java项目广泛依赖 的核心库,例如:集合 [collections] .缓存 [caching] .原生类型支持 [primitives support] ...
随机推荐
- 在 Javascript 中,为什么给 form 添加了 onsubmit 事件,为什么 IE7/8 还是会提交表单?
参考地址:http://stackoverflow.com/questions/4078245/onsubmit-return-false-has-no-effect-on-internet-expl ...
- 关于Idea突然无法输入的诡异问题解决
问题描述 最近加班把自己的装有Debian的笔记本带到公司,使用Idea写代码的时候,突然间无法输入,ctrl与tab还可用,重启Idea能得到一阵的解决 解决参考 如果是Linux平台,请考虑是否是 ...
- Laravel应用 -- 脚本任务
大多数项目在业务发展过程中,都需要修复历史数据和定时任务来完成一些业务逻辑,这部分通常都需要通过脚本来完成,一般的框架爱也都提供这部分的功能,学习并使用是工作中的基本要求. 基本流程 commands ...
- Centos安装jdk1.8出现-bash: //usr/local/soft/jdk1.8.0_191/bin/javac: /lib/ld-linux.so.2: bad ELF interpreter: 没有那个文件或目录错误。
1.从来没有这么郁闷,之前安装都是好好的,自从将Centos升级到7.0版本,安装了jdk报了这个错误,也是郁闷的一毛,参考了一下百度的,记录一下.使用java命令还有java -version命令都 ...
- django跳转页面传参
1.如果在反转url的时候,需要添加参数,那么可以通过传递'kwargs'参数到'reverse'函数中.实例代码: urls.py from django.urls import path, re_ ...
- Javaweb常用解决问题连接
1.javaweb的idea如何创建及配置web项目 https://www.jianshu.com/p/8d49d36a3c7e 2.servlet的建立以及部署 https://blog.csdn ...
- Freemarker简单封装
Freemarker是曾经很流行的一个模板库,它是一种通用的模板库,不仅仅可以用来渲染html. 模板可以分为两类: 只能生成特殊类型文件的模板,如jinja.django.Thymeleaf.jad ...
- JavaScript Date 日期属性和方法
JavaScript 日期(Date) Date对象用于处理日期和时间.使用对象new Date()创建日期.实例化日期有四种方式: var d1 = new Date(); var d2 = new ...
- mysql用查询结果当删除的判断条件进行删除报错1093 You can't specify target table解决方法
mysql用查询结果当删除的判断条件进行删除报错1093 You can't specify target table解决方法 #分开两个sql执行正常的语句,只保留最新1000条数据,删掉1000条 ...
- 轻量级手绘软件openCanvas免费版,手绘板CG手绘软件
轻量级手绘软件openCanvas免费版,手绘板CG手绘软件 手绘软件通俗一点来说就是用手来绘画的软件,应用很宽泛如建筑,服饰陈列设计.橱窗设计.家居软装设计.空间花艺设计.美术.园林.环艺.摄影.工 ...