Guava库介绍之集合(Collection)相关的API
作者:Jack47
转载请保留作者和原文出处
欢迎关注我的微信公众账号程序员杰克,两边的文章会同步,也可以添加我的RSS订阅源。
本文是我写的Google开源的Java编程库Guava系列之一,主要介绍Guava中提供的集合(Collection)相关的API。
1. 一些小功能##
集合声明更简单###
Java中同质的范型集合是一个很大的特色,但是有些时候他们的构造函数有点太啰嗦了,比如:
Map<String, Map<String, Integer>> lookup = new HashMap<String, Map<String, Integer>>();
在Java 7中通过钻石操作符<>
来允许有限的非正式的类型推导。上面的例子可以这样写:
Map<String, Map<String, Integer>> lookup = new HashMap<>();
Guava提供了一些使用范型来进行右侧类型推导的静态函数,使得集合的声明更简单,上面的例子可以这么写:
Map<String, Map<String, String>> map = Maps.newHashMap();
List<List<Map<String, String>>> list = Lists.newArrayList();
集合初始化更简单###
可以在集合声明时进行初始化
Set<String> set = Sets.newHashSet("one", "two", "three");
Map<String, String> map = ImmutableMap.of("ON", true, "OFF", false);
2. 不可变性(Immutability)##
大部分google提供的集合都提供不可变的版本。
当你不会修改一个集合,或者期望一个集合是固定不变的,那么一个很好的习惯是防御式地把它拷贝成一个不可变的集合。
注意
Guava中提供的不可变集合的实现是不允许有空值`null`的。因为通过研究Google内部代码库发现在集合中,只有5%的情况下是允许有空值的,剩下的95%情况下最好是遇到空值就快速失败(failing fast)。如果需要空值,可以使用JDK中提供的 Collections.unmodifiableList 这类允许空值的集合实现。
更多关于使用或者避免使用null
的细节见Using And Avoiding Null Explained
不可变的好处:
- 可以放心的给不信任的库使用
- 线程安全:可以被多个线程使用而不会有竞争条件发生
- 不需要同步(synchronization)的逻辑,不需要支持互斥
- 设计和实现很简单。所有不可变的集合实现比可变版本的内存效率要高,分析见这里
如何使用###
有多种方法来得到一个不可变的集合:
使用
of
函数ImmutableSet<Integer> numbers = ImmutableSet.of(10, 30, 40, 50);
使用
copyOf
函数ImmutableSet<Integer> another = ImmutableSet.copyOf(numberSet);
所有不可变的集合都通过asList()
提供了一个不可变的List(ImmutableList)视图。例如数据存储在一个ImmutableSortedSet
里,可以通过sortedSet.asList().get(k)
来获得第k
个最小的元素。
JDK虽然提供了Collections.unmodifiableXXX
方法,但是有一些问题:
- 非常笨重,使用起来很啰嗦,用着不爽
- 不安全:只有当没有对原始集合的引用时,这个函数返回的集合才是真的不可变的
- 不够高效:数据结构里还是有可变集合里关于并发修改的检查,存储哈希表的额外空间等。
3. 新的集合类型##
Guava引入的新的集合类型并没有暴露原始的构造函数,或者提供方便初始化操作的工具类,而是直接使用静态工厂函数,例如:
MultiMap<String, Integer> multiMap = HashMultiMap.create();
MultiMap###
容许一个key有多个值的MultiMap, MultiMap<K, V>
可以取代传统的Map<K, Collection<V>>
。也可以使用值为链表的ListMultiMap
或者集合SetMultiMap
。
Multiset###
Multiset支持添加多次相同的值,支持对值进行计数。
Multiset<Integer> multiSet = HashMultiset.create();
multiSet.add(10);
multiSet.add(30);
multiSet.add(30);
multiSet.add(40);
multiSet.count(30); // 2
multiSet.size(); // 4
Table###
表结构的数据类型Table
,它像Map一样,但是支持两种键--行键(row key)和列键(column key)。
4. 谓语(Predicate)和过滤器(Filter)##
谓语(Predicate)是一个只包含一个返回布尔类型的函数的简单接口。它的作用是给定一个输入,判断是否满足条件。它可以用来过滤集合,例如实现一个过滤出老客户的Predicate
。
static class LoyalCustomer implements Predicate<Customer> {
public boolean apply(Customer customer) {
return CustomerType.LOYAL == customer.getCustomerType();
}
}
Collection<Customer> loyalCustomers = Collections2.filter(customers, new LoyalCustomer());
filter函数的语法是:
Collection<E> filter(Collection<E> unfiltered, Predicate<E> predicate)
内置的Predicate####
Predicates
类包含了and
,or
,not
in
这几个静态函数来方便构建复杂的谓语。
Predicate<String> commonList = and(in(list1), in(list2, or(in(list3));
Predicates
类也包含了很多非常方便的函数,例如notNull
, instanceOf
, contains
等。
SortedMaps.filterValues(map, Predicates.notNull());
如果看到这里还意犹未尽的话,建议去看看源代码和单测的代码,里面有详尽的用法!
参考资料:
如果您看了本篇博客,觉得对您有所收获,请点击右下角的“推荐”,让更多人看到!
Guava库介绍之集合(Collection)相关的API的更多相关文章
- Guava库介绍之实用工具类
作者:Jack47 转载请保留作者和原文出处 欢迎关注我的微信公众账号程序员杰克,两边的文章会同步,也可以添加我的RSS订阅源. 本文是我写的Google开源的Java编程库Guava系列之一,主要介 ...
- java11 Guava:谷歌开发的集合库
Guava:谷歌开发的集合库,通过build path->Add External JARs 把guava.jar包加进去. 版本控制工具:.CVS .SVN .git 所以需要下载git客户端 ...
- GitHub上排名前100的Android开源库介绍(来自github)
本项目主要对目前 GitHub 上排名前 100 的 Android 开源库进行简单的介绍,至于排名完全是根据 GitHub 搜索 Java 语言选择 (Best Match) 得到的结果,然后过滤了 ...
- Guava 教程2-深入探索 Google Guava 库
原文出处: oschina 在这个系列的第一部分里,我简单的介绍了非常优秀的Google collections和Guava类库,并简要的解释了作为Java程序员,如果使用Guava库来减少项目中大量 ...
- GitHub上排名前100的Android开源库介绍
GitHub上排名前100的Android开源库介绍 文章来源: http://www.open-open.com/news/view/1587067#6734290-qzone-1-31660-bf ...
- DBoW2库介绍
DBoW2库是University of Zaragoza里的Lopez等人开发的开源软件库. 由于在SLAM回环检测上的优异表现(特别是ORB-SLAM2),DBoW2库受到了广大SLAM爱好者的关 ...
- WCF分布式开发步步为赢(8):使用数据集(DataSet)、数据表(DataTable)、集合(Collection)传递数据
数据集(DataSet).数据表(DataTable).集合(Collection)概念是.NET FrameWork里提供数据类型,在应用程序编程过程中会经常使用其来作为数据的载体,属于ADO.NE ...
- Common Lisp第三方库介绍 | (R "think-of-lisper" 'Albertlee)
Common Lisp第三方库介绍 | (R "think-of-lisper" 'Albertlee) Common Lisp第三方库介绍 一个丰富且高质量的开发库集合,对于实际 ...
- [集合]Collection集合框架源码分析
Collection接口 在java的集合类库中,基本接口是Collection,该接口的在集合中的源码定义如下(将源码中的注释删掉了): public interface Collection< ...
随机推荐
- 3.4.4 数据预留和对齐(skb_reserve, skb_push, skb_put, skb_pull)
转自:http://book.51cto.com/art/201206/345043.htm <Linux内核源码剖析:TCP/IP实现>本书详细论述了Linux内核2.6.20版本中TC ...
- 开发板tftp下载文件
搭建过程: 1.安装相关软件包:tftpd(服务端),tftp(客户端),xinetd sudo apt-get install tftpd tftp xinetd 2.建立配置文件(蓝色的目录是可以 ...
- 从零开始---控制台用c写俄罗斯方块游戏(2)
上回说到下移的问题,这篇就说一下刷新的问题 我们控制台输出一般都是一行一行的输出,所以,在输出屏幕的时候,我们一个画面闪到另一个画面的效果 我刚开始弄的是用system("CLS" ...
- display:inline-block的间隙问题和解决办法
1.display:inline-block在水平方向的间隙: 代码如下: <style type="text/css"> *{margin:0; padding:0; ...
- Servlet规范简介——web框架是如何注入到Servlet中的
Servlet规范简介--web框架是如何注入到Servlet中的 引言 Web框架一般是通过一个Servlet提供统一的请求入口,将指定的资源映射到这个servlet,在这个servlet中进行框架 ...
- 2016 ACM/ICPC Asia Regional Dalian Online 1010 Weak Pair dfs序+分块
Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 262144/262144 K (Java/Others)Total Submissio ...
- 普林斯顿算法课第四周作业_8Puzzle
作业地址:http://coursera.cs.princeton.edu/algs4/assignments/8puzzle.html 作业难点: 1.如何求一个Puzzle的解? 根据作业提示,使 ...
- JavaScript之基础篇
标识符 命名要求 以字母.下划线或者$开头: 由字母.下划线.$和数字组成. 关键字和保留字 关键字.保留字不可以作为标识符. 大小写敏感 区分大小写. 基本数据类型 Number 整数 浮点数 特殊 ...
- java并发J.U.C AtomicReference VS Volatile
SpinLock实现,摘自并发编程网 package com.juc.simple; import java.util.concurrent.atomic.AtomicReference; /** * ...
- 【转】《从入门到精通云服务器》第七讲—负载均衡和CDN技术
在IDC知识中,我们常常会遇上负载均衡与CDN的概念而不知所云.第一讲[什么是云计算], 我们提到过负载均衡,仅给大家留下了印象.这次我们将深入浅出的讲讲到底什么是负载均衡与CDN技术.---互联网数 ...