1、Lists

  1. //Lists
  2. System.out.println("### Lists ###");
  3. ArrayList<String> arrayList = Lists.newArrayList();
  4. arrayList.add("A");
  5. arrayList.add("B");
  6. arrayList.add("C");
  7. System.out.println(arrayList);
  8. LinkedList<String> linkedList = Lists.newLinkedList();
  9. linkedList.add("A");
  10. linkedList.add("B");
  11. linkedList.add("C");
  12. System.out.println(linkedList);
  13. System.out.println(Lists.reverse(arrayList));   //翻转集合元素的顺序
  14. System.out.println(Lists.reverse(linkedList));
  15. System.out.println(Lists.partition(arrayList, 2)); //一个集合内再分成n个子集合

2、Sets

  1. //Sets
  2. System.out.println("### Sets ###");
  3. HashSet<String> set1 = Sets.newHashSet();
  4. set1.add("A");
  5. set1.add("B");
  6. set1.add("C");
  7. LinkedHashSet<String> set2 = Sets.newLinkedHashSet();
  8. set2.add("B");
  9. set2.add("C");
  10. set2.add("D");
  11. set2.add("E");
  12. //Sets.newTreeSet();
  13. //Sets.newConcurrentHashSet();
  14. System.out.println(Sets.union(set1, set2)); //返回两个集合的并集  >> [A, B, C, D, E]
  15. System.out.println(Sets.difference(set1, set2)); //返回set1中不存在于set2的元素集合  >> [A]
  16. System.out.println(Sets.intersection(set1, set2)); //返回两个集合的交集  >> [B, C]
  17. Set<String> resultSet = Sets.filter(set2, new Predicate<String>() {
  18. @Override
  19. public boolean apply(String value) {
  20. return !"D".equals(value); //过滤掉值为D的元素  >> [B, C, E]
  21. }
  22. });
  23. System.out.println(resultSet);

3、Maps

  1. //Maps
  2. System.out.println("### Maps ###");
  3. Maps.newHashMap();
  4. Maps.newLinkedHashMap();
  5. Maps.newTreeMap();
  6. Maps.newConcurrentMap();

4、Collections2

  1. //Collections2
  2. System.out.println("### Collections2 ###");
  3. Collection<String> linkedList2 = Collections2.filter(linkedList, new Predicate<String>() {
  4. @Override
  5. public boolean apply(String value) {
  6. return !"B".equals(value); //过滤器:过滤掉值为B的元素  >> [A, C]
  7. }
  8. });
  9. System.out.println(linkedList2);
  10. Collection<String> linkedList3 = Collections2.transform(linkedList, new Function<String, String>() {
  11. @Override
  12. public String apply(String value) {
  13. return value + "_"; //转换器:元素值做特殊处理后返回  >> [A_, B_, C_]
  14. }
  15. });
  16. System.out.println(linkedList3);

Lists、Sets、Maps和Collections2的使用的更多相关文章

  1. java代码之美(9)---guava之Lists、Maps

    guava之Lists.Maps 谷歌提供了guava包里面有很多的工具类,Lists和Maps集合工具,集合操作做了些优化提升. 1.概述 1.静态工厂方法 (1)Guava提供了能够推断范型的静态 ...

  2. java代码(9) ---guava之Lists、Maps

     guava之Lists.Maps 谷歌提供了guava包里面有很多的工具类,Lists和Maps集合工具,集合操作做了些优化提升 一.概述 1.静态工厂方法 (1)Guava提供了能够推断泛型的静态 ...

  3. 005-guava 集合-集合工具类-java.util.Collections中未包含的集合工具[Maps,Lists,Sets],Iterables、Multisets、Multimaps、Tables

    一.概述 工具类与特定集合接口的对应关系归纳如下: 集合接口 属于JDK还是Guava 对应的Guava工具类 Collection JDK Collections2:不要和java.util.Col ...

  4. java成神之——集合框架之ArrayList,Lists,Sets

    集合 集合种类 ArrayList 声明 增删改查元素 遍历几种方式 空集合 子集合 不可变集合 LinkedList Lists 排序 类型转换 取交集 移动元素 删除交集元素 Sets 集合特点 ...

  5. Guava中Predicate的常见用法

    Guava中Predicate的常见用法 1.  Predicate基本用法 guava提供了许多利用Functions和Predicates来操作Collections的工具,一般在 Iterabl ...

  6. Chapter 7 -- Functional

    Caveats 说明 As of Java 7, functional programming in Java can only be approximated through awkward and ...

  7. [Java Basics] Collection

    除了Java collection class/interface外,方便的有Google guava的utility class: Lists/Sets/Maps/Queues, 用它们可以方便地创 ...

  8. Thymeleaf模板的使用

    使用模板的要点:     页面主体结构固定,具体参数可变,尽可能让参数动态化,才能提高模板的复用性 ================================================== ...

  9. Guava学习笔记:EventBus(转)

    EventBus是Guava的事件处理机制,是设计模式中的观察者模式(生产/消费者编程模型)的优雅实现.对于事件监听和发布订阅模式,EventBus是一个非常优雅和简单解决方案,我们不用创建复杂的类和 ...

随机推荐

  1. 深入了解 WPF Dispatcher 的工作原理(PushFrame 部分)

    在上一篇文章 深入了解 WPF Dispatcher 的工作原理(Invoke/InvokeAsync 部分) 中我们发现 Dispatcher.Invoke 方法内部是靠 Dispatcher.Pu ...

  2. 《selenium2 python 自动化测试实战》(5)——键盘事件

    键盘事件,就是键盘上的一些操作,比如Ctrl +C,Ctrl+V,Ctrl+X等. 对键盘的操作需要导入另一个键盘的库: from selenium.webdriver.common.keys imp ...

  3. Codeforces Round #249 (Div. 2)-D

    这场的c实在不想做,sad. D: 标记一下每个点8个方向不经过黑点最多能到达多少个黑点. 由题意可知.三角形都是等腰三角形,那么我们就枚举三角形的顶点. 对于每个定点.有8个方向能够放三角形. 然后 ...

  4. 什么是spark(五)Spark SQL

       Spark SQL Spark SQL主要分为两部分,一部分是Spark Sql在scala中直接,使用作为执行层面上的应用,本质上就是生成DAG的另外一种形式:其发生试下Driver中生成: ...

  5. bzoj1040(ZJOI2008)骑士——基环树

    题目:https://www.lydsy.com/JudgeOnline/problem.php?id=1040 基环树的模板. 套路就是把环断开,先把一端作为根节点,强制不选:再把另一端作为根节点, ...

  6. 下ue节点

    #!/bin/bash action=$1 port=$2 file="/home/operation/workspace/renderingengine/engine/services.t ...

  7. 搭建基于hyperledger fabric的联盟社区(五) --启动Fabric网络

    现在所有的文件都已经准备完毕,我们可以启动fabric网络了. 一.启动orderer节点 在orderer服务器上运行: cd ~/go/src/github.com/hyperledger/fab ...

  8. nginx和php-fpm通信的两种方式 unix socket和TCP

    nginx和fastcgi的通信方式有两种,一种是TCP 一种是unix socket TCP使用的是 127.0.0.1:9000端口,将fastcgi_pass参数修改为127.0.0.1:900 ...

  9. AngularJS.js: temple

    ylbtech-AngularJS.js: temple 1.返回顶部   2.返回顶部   3.返回顶部   4.返回顶部   5.返回顶部     6.返回顶部   7.返回顶部   8.返回顶部 ...

  10. Linut ssh sftp服务重启

    在网上,收了半天,终于找到这个,记录一下~哈~ RedHat Linux 重启SSH /etc/init.d/sshd restart 重启SFTP /etc/init.d/vsftpd restar ...