分享

JAVA基础 之 Collections

 hehffyy 2013-02-26

概述:

    1.Collections(注意不是Collection,而是Collections,多了一个s)

    2.它是一个集合工具类

    3.方法分类:常规操作(查找,最大,最小等)、排序、线程安全(同步)操作、不可变集合

Java代码: 
  1. package com.cxy.collection;    
  2. import java.util.ArrayList;  
  3. import java.util.Arrays;  
  4. import java.util.Collections;  
  5. import java.util.HashMap;  
  6. import java.util.HashSet;  
  7. import java.util.List;  
  8. import java.util.Map;  
  9. import java.util.Set;  
  10. import java.util.TreeSet;  
  11.   
  12. /** 
  13.  * @author cxy 
  14.  */  
  15. public class CollectionsTest  
  16. {  
  17.     public static void main(String[] args)  
  18.     {  
  19.         List l=new ArrayList();  
  20.         l.add(100);  
  21.         l.add(-66);  
  22.         l.add(0);  
  23.         l.add(88);  
  24.           
  25.         System.out.println("list:"+l);  
  26.           
  27.         Collections.reverse(l);  
  28.         System.out.println("反转后的list:"+l);  
  29.           
  30.         Collections.shuffle(l);  //随机排序,洗牌  
  31.         System.out.println("乱序后的list:"+l);  
  32.           
  33.         Collections.swap(l, 13);  
  34.         System.out.println("互换序号是1,3元素后的list:"+l);  
  35.           
  36.         Collections.sort(l);  //这里是个自然排序,更多排序内容请参见本博客中的《JAVA应用 之 排序》  
  37.         System.out.println("排序后的list:"+l);  
  38.           
  39.         Collections.binarySearch(l, 88); //二分查找,必须保证list处于有序状态,查询成功返回序号,查不到返回负数  
  40.   
  41.         System.out.println("list中最小的元素是:"+Collections.min(l));  
  42.         System.out.println("list中最大的元素是:"+Collections.max(l));  
  43.         //上面两个方法 是自然排序,当然您可以自己实现一个Comparator的实现类作为第二个参数,具体见《JAVA应用 之 排序》  
  44.           
  45.         l.add(88);  
  46.         //88(第二个参数)在list(第一个参数)出现过多少次  
  47.         System.out.println("88在list中出现了:"+Collections.frequency(l, 88)+"次");  
  48.           
  49.         Collections.replaceAll(l, 8866); //将88用66去替代  
  50.         System.out.println("替代后的list:"+l);  
  51.           
  52.         Collections.fill(l, 66); //使用66(第二个参数)替换list中的所有元素。  
  53.         System.out.println("list所有元素都被替换成为66:"+l);  
  54.           
  55.         //下面写法的意思是创建一个l这么大的l1,不这么写会报异常,因为copy的时候不会自动扩容  
  56.         List l1=new ArrayList(Arrays.asList(new Object[l.size()]));  
  57.         Collections.copy(l1, l);  
  58.         System.out.println("拷贝l的l1:"+l1);  
  59.         System.out.println("l和l1是否相等?"+l.equals(l1));  
  60.         System.out.println("l和l1是否是一个引用?"+ (l==l1));  
  61.         l1=l;  
  62.         System.out.println("l和l1是否相等?"+l.equals(l1));  
  63.         System.out.println("l和l1是否是一个引用?"+ (l==l1));  
  64.         l1=new ArrayList(l); //这个是一个浅拷贝,l和l1的引用虽然不同,但是l和l1内部的元素引用还是一样的  
  65.         System.out.println("l和l1是否相等?"+l.equals(l1));  
  66.         System.out.println("l和l1是否是一个引用?"+ (l==l1));  
  67.         //上面的问题有些复杂 以后形成一个专题讲解  
  68.           
  69.         //创建一个类型安全的集合,下面的意思是这个集合只能是再添加Integer类型数据  
  70.         l.add("abc");  //现在还没事~  
  71.         try  
  72.         {  
  73.             Collections.checkedList(l, Integer.class).add("abc");  
  74.         }catch(Exception e)  
  75.         {  
  76.             System.out.println("类型安全操作后,当你再试图添加非Integer类型数据时 发生了异常");  
  77.         }  
  78.         System.out.println("======================");  
  79.           
  80.         /* 注意常用的这些集合(HashSet、HashMap、ArrayList、TreeMap、TreeSet、LinkedList等), 
  81.          * 都不是线程安全的,如果您的程序是在多线程环境下 并且有可能会同时修改同一个集合,那么 
  82.          * 您就需要使用Collections.synchronizedXxx 方法来保证线程安全 
  83.          */  
  84.         List sl=Collections.synchronizedList(new ArrayList());  
  85.         Map sm=Collections.synchronizedMap(new HashMap());  
  86.         Set ss=Collections.synchronizedSet(new HashSet());  
  87.         Set sts=Collections.synchronizedSortedSet(new TreeSet());  
  88.           
  89.         /* 不可变集合(空集合、指定元素集合、不可变状态) 
  90.          * 1.使用Collections.emptyXxx 方法来创建一个不可变化的空集合 
  91.          * 2.空不可变集合的意义:不会因为赋值null那样带来不可预期的异常,个人理解就是初始化的最佳实践。 
  92.         * 3.指定元素集合:返回一个只包含指定元素的集合,同时也是不可变化的集合 
  93.          *   应用:创建一个不可变化的特殊对象集合,例如:管理员集合,这样这个管理员对象就可以拥有一些集合的方法了 
  94.          *       例如:我判断一些这个用户对象是否是管理员(adminList.contains(user)) 
  95.          * 4.不可变状态:获得这个集合的不可变试图(只读) 
  96.          * 3.这里之用list举例,其他集合类似 
  97.         */  
  98.         List<String> el=Collections.emptyList();  
  99.         System.out.println(el.isEmpty());  
  100.   
  101.         try  
  102.         {  
  103.             el.add("1");  //如果试图改变它 那么就会抛出UnsupportedOperationException异常  
  104.         }catch(Exception e)  
  105.         {  
  106.             System.out.println("UnsupportedOperationException");  
  107.         }  
  108.         List<String> el1=null;  //通常我们可能习惯这样定义一个list  
  109.         try  
  110.         {  
  111.             el1.contains("abc");  //可能在某个地方我们不小心的这样用了(假设这个存在于一个低概率发生的地方)  
  112.         }catch(Exception e)  
  113.         {  
  114.             System.out.println("null异常");  
  115.       }   
  116.         List<String> singletonL=Collections.singletonList("abcd");  
  117.         System.out.println(singletonL);  
  118.           
  119.         //通过下面的方式就能得到一个不可变化的(只读)集合(视图的感觉,官方其实也是这么介绍的)  
  120.         List<String> listView=Collections.unmodifiableList(l);  
  121.     }  

    本站是提供个人知识管理的网络存储空间,所有内容均由用户发布,不代表本站观点。请注意甄别内容中的联系方式、诱导购买等信息,谨防诈骗。如发现有害或侵权内容,请点击一键举报。
    转藏 分享 献花(0

    0条评论

    发表

    请遵守用户 评论公约

    类似文章 更多