搜索
有爱,有技术,有你^_^)y
╱人◕‿‿◕人╲订下契约(注册新用户)

合作站点账号登陆

QQ登录

只需一步,快速开始

快捷导航
查看: 2323|回复: 2
收起左侧

[Java] JAVA基础 之 Collections(我是搬运的)

 关闭 [复制链接]

签到天数: 1 天

连续签到: 1 天

[LV.1]初来乍到

20

主题

27

好友

1万

积分

第一章

积分
11792
发表于 2013-2-24 11:41:56 | 显示全部楼层 |阅读模式

╱人◕‿‿◕人╲定下契约

您需要 登录 才可以下载或查看,没有账号?╱人◕‿‿◕人╲订下契约(注册新用户)

x
概述:
    1.Collections(注意不是Collection,而是Collections,多了一个s)
    2.它是一个集合工具类
    3.方法分类:常规操作(查找,最大,最小等)、排序、线程安全(同步)操作、不可变集合

[mw_shl_code=java,true]package com.cxy.collection;  
  
import java.util.ArrayList;  
import java.util.Arrays;  
import java.util.Collections;  
import java.util.HashMap;  
import java.util.HashSet;  
import java.util.List;  
import java.util.Map;  
import java.util.Set;  
import java.util.TreeSet;  
  
/**
* @author cxy
*/  
public class CollectionsTest  
{  
    public static void main(String[] args)  
    {  
        List l=new ArrayList();  
        l.add(100);  
        l.add(-66);  
        l.add(0);  
        l.add(88);  
         
        System.out.println("list:"+l);  
         
        Collections.reverse(l);  
        System.out.println("反转后的list:"+l);  
         
        Collections.shuffle(l);  //随机排序,洗牌  
        System.out.println("乱序后的list:"+l);  
         
        Collections.swap(l, 1, 3);  
        System.out.println("互换序号是1,3元素后的list:"+l);  
         
        Collections.sort(l);  //这里是个自然排序,更多排序内容请参见本博客中的《JAVA应用 之 排序》  
        System.out.println("排序后的list:"+l);  
         
        Collections.binarySearch(l, 88); //二分查找,必须保证list处于有序状态,查询成功返回序号,查不到返回负数  
  
        System.out.println("list中最小的元素是:"+Collections.min(l));  
        System.out.println("list中最大的元素是:"+Collections.max(l));  
        //上面两个方法 是自然排序,当然您可以自己实现一个Comparator的实现类作为第二个参数,具体见《JAVA应用 之 排序》  
         
        l.add(88);  
        //88(第二个参数)在list(第一个参数)出现过多少次  
        System.out.println("88在list中出现了:"+Collections.frequency(l, 88)+"次");  
         
        Collections.replaceAll(l, 88, 66); //将88用66去替代  
        System.out.println("替代后的list:"+l);  
         
        Collections.fill(l, 66); //使用66(第二个参数)替换list中的所有元素。  
        System.out.println("list所有元素都被替换成为66:"+l);  
         
        //下面写法的意思是创建一个l这么大的l1,不这么写会报异常,因为copy的时候不会自动扩容  
        List l1=new ArrayList(Arrays.asList(new Object[l.size()]));  
        Collections.copy(l1, l);  
        System.out.println("拷贝l的l1:"+l1);  
        System.out.println("l和l1是否相等?"+l.equals(l1));  
        System.out.println("l和l1是否是一个引用?"+ (l==l1));  
        l1=l;  
        System.out.println("l和l1是否相等?"+l.equals(l1));  
        System.out.println("l和l1是否是一个引用?"+ (l==l1));  
        l1=new ArrayList(l); //这个是一个浅拷贝,l和l1的引用虽然不同,但是l和l1内部的元素引用还是一样的  
        System.out.println("l和l1是否相等?"+l.equals(l1));  
        System.out.println("l和l1是否是一个引用?"+ (l==l1));  
        //上面的问题有些复杂 以后形成一个专题讲解  
         
        //创建一个类型安全的集合,下面的意思是这个集合只能是再添加Integer类型数据  
        l.add("abc");  //现在还没事~  
        try  
        {  
            Collections.checkedList(l, Integer.class).add("abc");  
        }catch(Exception e)  
        {  
            System.out.println("类型安全操作后,当你再试图添加非Integer类型数据时 发生了异常");  
        }  
        System.out.println("======================");  
         
        /* 注意常用的这些集合(HashSet、HashMap、ArrayList、TreeMap、TreeSet、LinkedList等),
         * 都不是线程安全的,如果您的程序是在多线程环境下 并且有可能会同时修改同一个集合,那么
         * 您就需要使用Collections.synchronizedXxx 方法来保证线程安全
         */  
        List sl=Collections.synchronizedList(new ArrayList());  
        Map sm=Collections.synchronizedMap(new HashMap());  
        Set ss=Collections.synchronizedSet(new HashSet());  
        Set sts=Collections.synchronizedSortedSet(new TreeSet());  
         
        /* 不可变集合(空集合、指定元素集合、不可变状态)
         * 1.使用Collections.emptyXxx 方法来创建一个不可变化的空集合
         * 2.空不可变集合的意义:不会因为赋值null那样带来不可预期的异常,个人理解就是初始化的最佳实践。
         * 3.指定元素集合:返回一个只包含指定元素的集合,同时也是不可变化的集合
         *   应用:创建一个不可变化的特殊对象集合,例如:管理员集合,这样这个管理员对象就可以拥有一些集合的方法了
         *       例如:我判断一些这个用户对象是否是管理员(adminList.contains(user))
         * 4.不可变状态:获得这个集合的不可变试图(只读)
         * 3.这里之用list举例,其他集合类似
        */  
        List<String> el=Collections.emptyList();  
        System.out.println(el.isEmpty());  
  
        try  
        {  
            el.add("1");  //如果试图改变它 那么就会抛出UnsupportedOperationException异常  
        }catch(Exception e)  
        {  
            System.out.println("UnsupportedOperationException");  
        }  
         
        List<String> el1=null;  //通常我们可能习惯这样定义一个list  
        try  
        {  
            el1.contains("abc");  //可能在某个地方我们不小心的这样用了(假设这个存在于一个低概率发生的地方)  
        }catch(Exception e)  
        {  
            System.out.println("null异常");  
        }  
         
        List<String> singletonL=Collections.singletonList("abcd");  
        System.out.println(singletonL);  
         
        //通过下面的方式就能得到一个不可变化的(只读)集合(视图的感觉,官方其实也是这么介绍的)  
        List<String> listView=Collections.unmodifiableList(l);  
    }  
}  [/mw_shl_code]

原文链接:http://blog.csdn.net/luckcxy/article/details/8606475

评分

参与人数 1宅币 +20 贡献 +3 元气(技能点) +1 收起 理由
Mr_Alex + 20 + 3 + 1 嗯 集合这块目前用的还不多

查看全部评分

签名被小宅喵吞掉了~~~~(>_<)~~~~
回复

使用道具 举报

签到天数: 1 天

连续签到: 1 天

[LV.1]初来乍到

20

主题

27

好友

1万

积分

第一章

积分
11792
 楼主| 发表于 2013-2-24 15:50:43 | 显示全部楼层
@Mr_Alex 你可以看看我分享的这篇文章最后的那个链接.下面还有其他的.比方说List,Set..这些都是常用的.因为有链接到原文章地址.所以我就没转过来
签名被小宅喵吞掉了~~~~(>_<)~~~~
回复 支持 反对

使用道具 举报

签到天数: 3 天

连续签到: 1 天

[LV.2]偶尔看看I

41

主题

60

好友

2万

积分

第一章

守望者

积分
21763
发表于 2013-2-24 20:38:19 | 显示全部楼层

嗯 在CSDN上收藏了
如果有来生,要做一棵树,站成永恒,没有悲欢的姿势。一半在土里安详,一半在风里飞扬,一半洒落阴凉,一半沐浴阳光,非常沉默非常骄傲,从不依靠从不寻找。
回复 支持 反对

使用道具 举报

本版积分规则

小黑屋|手机版|技术宅(Z站|基宅) ( 粤ICP备18082987号-1 )

GMT+8, 2025-6-18 15:12 , Processed in 0.091329 second(s), 15 queries , Redis On.

Copyright © 2018 技术宅社区

Powered by Discuz! X3.5

快速回复 返回顶部 返回列表