一、Collections工具类概述

  1、为List、Set、Map等集合提供大量方法对集合元素进行排序、查询和修改等操作。

  2、将集合对象设置为不可变。

  3、对集合对象实现同步控制等。

二、排序操作

  a、void reverse(List list):反转指定List集合里的元素。

  b、void shuffle(List list):对List集合元素进行随机排序(模拟洗牌动作)。

  c、void sort(List list):根据元素的自然顺序对指定List集合的元素按升序进行排序。

  d、void sort(List list,Comparator c):根据指定的Comparator产生的顺序对List集合元素进行排序。

  e、void swap(List list,int i,int j):将List集合中的i,j元素进行交换。

  f、void rotate(List list,int distance):当distance为正数时,将list集合的后distance元素整体移到前面,当distance为负数时,将list集合的前distance元素整体移到后面,该操作不会改变list长度。

  下面简单示范了Collections工具类对List集合的操作: 

 import java.util.ArrayList;
 import java.util.Collections;

 public class Main {
     public static void main(String[] args) {
         ArrayList al = new ArrayList<>();
         al.add(1);
         al.add(6);
         al.add(3);
         System.out.println(al);
         Collections.reverse(al);
         System.out.println(al);
         Collections.sort(al);
         System.out.println(al);
         Collections.shuffle(al);
         System.out.println(al);
     }
 }
 [1, 6, 3]
 [3, 6, 1]
 [1, 3, 6]
 [6, 3, 1]

三、查找、替换操作类方法

  a、int binarySearch(List list,Object key):使用二分法查找指定List集合,以获得指定对象在List中索引,前提是List处于有序状态。

  b、Object max(Collection coll):根据元素的插入顺序,返回给定集合中的最大元素。

  c、Object max(Collection coll,Comparator comp):根据Comparator指定的顺序,返回给定集合中的最大元素。 

  d、Object min(Collection coll):根据元素的插入顺序,返回给定集合中的最小元素。

  e、Object min(Collection coll,Comparator comp):根据Comparator指定的顺序,返回给定集合中的最小元素。

  f、void fill(List list,Object obj):使用指定元素Object,替换指定List集合中的所有元素。

  g。int frequency(Collection c,Object o):返回指定集合中指定元素的出现次数。

  h、int indexOfSubList(List source,List target):返回子List对象在父List对象第一次出现的位置索引,父List没有这样的子List,返回-1.

  i、boolean replaceAll(List list,Object oldVal,Object newVal):使用一个新newVal值替换List对象的所有旧值oldVal。

  下面的程序进行简单示范:  

 import java.util.ArrayList;
 import java.util.Collections;

 public class Main {
     public static void main(String[] args) {
         ArrayList al = new ArrayList<>();
         al.add(1);
         al.add(6);
         al.add(3);
         al.add(3);
         al.add(-1);
         al.add(4);
         System.out.println(al);
         System.out.println("-----------------");
         System.out.println(Collections.max(al));
         System.out.println(Collections.min(al));
         System.out.println("-----------------");
         Collections.replaceAll(al, 3, 10);
         System.out.println(al);
         System.out.println("-----------------");
         Collections.sort(al);
         System.out.println(al);
         System.out.println(Collections.binarySearch(al, 4));
     }
 }
 [1, 6, 3, 3, -1, 4]
 -----------------
 6
 -1
 -----------------
 [1, 6, 10, 10, -1, 4]
 -----------------
 [-1, 1, 4, 6, 10, 10]
 2

四、同步控制

  Collections类提供多个synchronizedXxx()方法,可以将指定集合包装为线程同步集合,解决多线程并发访问的线程安全问题。

  常用集合HashSet、TreeSet、ArrayList、ArrayDeque、LinkedList、HashMap、TreeMap都是线程不安全的。

  下面的实例创建了四个线程安全的集合: 

 import java.util.ArrayList;
 import java.util.Collection;
 import java.util.Collections;
 import java.util.HashMap;
 import java.util.HashSet;
 import java.util.List;
 import java.util.Map;
 import java.util.Set;

 public class Main {
     public static void main(String[] args) {
         Collection collection = Collections.synchronizedCollection(new ArrayList<>());
         List list = Collections.synchronizedList(new ArrayList<>());
         Set set = Collections.synchronizedSet(new HashSet<>());
         Map map = Collections.synchronizedMap(new HashMap<>());

     }
 }

五、设置不可变集合

  设置不可变集合,可以生产“只读”的Collection或Map。

  通过以下三个方法可以设置:

  a、emptyXxx():返回一个空的、不可变的集合对象。

  b、singletonXxx():返回一个包含指定对象(只有一个或一项元素)的、不可变的集合对象。

  c、unmodifiableXxx():返回指定集合对象的不可变视图。

  以下程序简单示范一般用法和改变集合的异常: 

 import java.util.Collections;
 import java.util.HashMap;
 import java.util.List;
 import java.util.Map;
 import java.util.Set;

 public class Main {
     public static void main(String[] args) {
         List ueList = Collections.emptyList();
         Set ueSet = Collections.singleton(new String("single"));
         Map scorse = new HashMap<>();
         scorse.put("yuwen", 100);
         Map uescorse = Collections.unmodifiableMap(scorse);
         uescorse.put(10, 20);
         ueList.add(10);
         ueSet.add(100);
     }
 }
 Exception in thread "main" java.lang.UnsupportedOperationException
     at java.util.Collections$UnmodifiableMap.put(Unknown Source)
     at Main.main(Main.java:14)

【Java】集合_Collections_学习记录的更多相关文章

  1. Java集合框架学习(一)List

    先附一张Java集合框架图. 从上面的集合框架图可以看到,Java集合框架主要包括两种类型的容器,一种是集合(Collection),存储一个元素集合,另一种是图(Map),存储键/值对映射.Coll ...

  2. java 项目相关 学习记录

    一位资深程序员大牛给予Java初学者的学习路线建议  [任何时期都可以好好看看] https://www.imooc.com/article/8993 https://www.jianshu.com/ ...

  3. java集合的学习笔记

    不知不觉也到了java集合这一章的学习,这因该是挺重要的一个章节,因为所有的程序都离不开数据,而一个良好的数据结构和算法应该是程序的灵魂吧. 今天对自己所初步了解的做一个总结: 数据结构是计算机存储. ...

  4. Java集合框架学习

    集合框架 集合框架的目标 该框架必须是高性能的.基本集合(动态数组,链表,树,哈希表)的实现必须是高效的. 该框架允许 不同类型的集合,以类似的方式工作,具有高度的互操作性. 对一个集合的扩展和适应必 ...

  5. Java集合框架学习总结

    转自:http://www.cnblogs.com/oubo/archive/2012/01/07/2394639.html Oubo的博客 以下介绍经常使用的集合类,这里不介绍集合类的使用方法,只介 ...

  6. 转:java高并发学习记录-死锁,活锁,饥饿

    死锁 两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去. 为什么会产生死锁: ① 因为系统资源不足. ② 进程运行推进的顺序不合适.    ③ ...

  7. 【java基础 11】java集合框架学习

    导读:本篇博客主要是从整体上了解java的集合框架,然后主要介绍几个自己在项目中用到的结构,比如说:hashtable.hashmap.hashset.arraylist等! 一.宏观预览 从宏观上看 ...

  8. Java集合框架学习笔记

    集合类的由来:对象用于封装特有数据,对象多了需要存储,如果对象的长度不确定,就使用集合存储. 集合特点1.用于存储对象的容器.2.集合的长度可变.3.集合中不可以存储基本类型 集合容器因为内部的数据结 ...

  9. JAVA 动态代理学习记录

    打算用JAVA实现一个简单的RPC框架,看完RPC参考代码之后,感觉RPC的实现主要用到了两个方面的JAVA知识:网络通信和动态代理.因此,先补补动态代理的知识.---多看看代码中写的注释 参考:Ja ...

随机推荐

  1. JSP三个指令及9个内置对象

    注:本文编写方便自己以后用到时查阅 三大指令:include. page.taglib include指令:  作用: 在当前页面用于包含其他页面 语法: <%@include file=&qu ...

  2. PHP设计模式之:工厂模式

    工厂模式: 由工厂类根据参数来决定创建出哪一种产品类的实例: 工厂类是指包含了一个专门用来创建其他对象的方法的类.所谓按需分配,传入参数进行选择,返回具体的类.工厂模式的最主要作用就是对象创建的封装. ...

  3. WinForm控件复杂数据绑定常用数据源(对Combobox,DataGridView等控件DataSource赋值的多种方法)

    开始以前,先认识一下WinForm控件数据绑定的两种形式,简单数据绑定和复杂数据绑定. 1) 简单数据绑定 简单的数据绑定是将用户控件的某一个属性绑定至某一个类型实例上的某一属性.采用如下形式进行绑定 ...

  4. JavaScript学习总结【5】、JS DOM

    1.DOM 简介 当页面加载时,浏览器会创建页面的文档对象模型(Document Object Model).文档对象模型定义访问和处理 HTML 文档的标准方法.DOM 将 HTML 文档呈现为带有 ...

  5. nodejs compressor

    http://www.2cto.com/kf/201203/122015.html http://www.cnblogs.com/terrylin/archive/2013/06/01/3112596 ...

  6. C语言嵌入式系统编程修炼之六:性能优化

    使用宏定义 在C语言中,宏是产生内嵌代码的唯一方法.对于嵌入式系统而言,为了能达到性能要求,宏是一种很好的代替函数的方法. 写一个"标准"宏MIN ,这个宏输入两个参数并返回较小的 ...

  7. 10.在Global全局文件中的Application_BeginRequest示例

    只要有人访问本网站,都要执行全局文件的Application_BeginRequest事件.因此我们可以防盗链. 示例要求:凡不是网站本机登录的都给客户端提示,用图片显示. 分析:由于网页在加载时不是 ...

  8. Java多线程同步方法Synchronized和volatile

    11 同步方法  synchronized – 同时解决了有序性.可见性问题  volatile – 结果可见性问题 12 同步- synchronized synchronized可以在任意对象上加 ...

  9. shell 执行jar 的命令

    #!/bin/sh ############## #判断是否程序已启动 jappname='Test' mainclasspath="com.company.commontest.test& ...

  10. Selenium 处理模态对话框

    模态对话框的原理 模态窗口 点击下一步的动作为,聚焦到“下一步”,然后直接回车 driver.FindElement(By.CssSelector("div.rg_btn a")) ...