聚集Collection的技巧

简介:
1、  MAP
特点:同键的新值将覆盖旧值。
示例:
        Map<String, String> map =  new HashMap<String, String>();
        String str;
        str = map.put("1", "a");  // str=null
        str = map.put("1", "b"); // str=a
        str = map.put("1", "c");  // str=b 新值覆盖旧值,最后map只有(1,c)一个值。返回的b是被覆盖的值

循环遍历:
        Map<String, Long> map =  new HashMap<String, Long>();
        map.put("a",  new Long(1));
        map.put("b",  new Long(2));

         for (Map.Entry<String, Long> entry : map.entrySet()) {
            String key = entry.getKey();
            Long value = entry.getValue();
        }

2、Set
特点:无序排列,不会存在重复的值,添加重复值也不会报错.Set可以加入null值
示例:
        Set < String >  set  =    new  HashSet < String > ();
          boolean  b;
        b  =  set.add( " 1 " );  //  b=true 
        b  =  set.add( " 2 " );  //  b=true 
        b  =  set.add( " 1 " );  //  b=false 
        b  =  set.add( " 2 " );  //  b=false 返回值为false,表示没有加入

3、List
特点:有序排序,可以加入重复的元素
示例:
        Arrays.asList(  new  String[] { " 11 " ,  " 222 "  });  //  返回一个不可改的List 
        List < String >  l  =  Arrays.asList( " 11 " ,  " 222 " ,  " 333 " );
        l.subList( 1 ,  2 );   //  由第二个和第三个元素生成一个新List 

        ArrayList < String >  list  =    new  ArrayList < String > (l);   //  生成一个可改的List 
          boolean  b;
        b  =  list.add( " 11 " );  //  b=true  List可以加入重复的元素 
        b  =  list.add( " 11 " );  //  b=true

4、Collections
特点:Collections.class是集合的工具方法类
示例:
        List<String> list1 =  new ArrayList<String>();
        List<String> list =  new ArrayList<String>();

        Collections.sort(list);  // 排序
         int pos = Collections.binarySearch(list, "key"); // 用二叉树算法来查找,首先得排序好
        System.out.println("pos=" + pos);

        Collections.copy(list, list1);  // 把list1复制到list上,原list元素被覆盖
        Collections.fill(list, "ss");  // 用"ss"填充list
        Collections.max(list);  // 找最大元素
        Collections.reverse(list);  // 把排序
        Collections.shuffle(list); // 混乱排序

        Collections.singleton("ss"); // 返回一个Set集合,不可改,只有ss一个元素
        Collections.unmodifiableList(list); // 返回一个不可改的新的List,原list不变
        Collections.synchronizedList(list); // 返回一个同步的新的List,原list不变

5、Properties
特点:Properties继承自Hashtable,是Map的一个实现。不过它在读取Properties文件方法特别方便
示例:
        Properties p = System.getProperties();  // 得到系统属性
        p.list(System.out); // 打印所有

         /*
         * 从user.home=C:\Documents and Settings\chengang
         * 读取properties文件填充到Properties
         
*/
        Properties p2 = System.getProperties();  // 得到系统属性
        File file =  new File(p.getProperty("user.home"), "argo.user.properties");
        p2.load( new FileInputStream(file));
        System.err.println("------------------------------");
        p2.list(System.out);
目录
相关文章
|
SQL 关系型数据库 MySQL
使用索引消除group by 排序
ySQL数据库在使用group by查询时默认会进行排序,有时候我们并不需要这种排序,消除这种排序有两种方式,本文介绍其中一种,即使用索引消除排序,这种方式还有一个附加的好处,就是避免临时表的创建。
688 0
|
4月前
|
存储 Java 索引
Collection集合
Collection集合
|
7月前
|
索引
单列集合顶层接口Collection
单列集合顶层接口Collection
44 1
|
7月前
|
存储 Java 索引
集合进阶Collection集合
这篇文档介绍了Java中的Collection集合和其子类List与Set的基本概念和特性。
63 3
|
C#
c#集合去重&排序常用方法
list和数组转Hashset跟SortedSet进行排序和去重,以及当Hashset和SortedSet存放的是类时如何进行自定义的排序和去重
100 2
|
存储 监控 Java
Set集合去重(详细篇)
Set集合去重(详细篇)
222 0
|
Java 索引
Collection 集合的遍历
Collection 集合的遍历
68 0
|
存储 缓存 索引
PG13 B-tree索引去重
PG13 B-tree索引去重
99 0
|
存储 NoSQL Redis
Sorted Set源码阅读,有序集合为何能同时支持点查询和范围查询
Sorted Set源码阅读,有序集合为何能同时支持点查询和范围查询
49 0
|
存储 算法 安全