zoukankan      html  css  js  c++  java
  • JAVA集合小结

    转自:http://www.blogjava.net/EvanLiu/archive/2007/11/12/159884.html

    ————————————————————————————————————————————

    还有一张下载来的:

     

    有序否

    允许元素重复否

    Collection

    List

    Set

    AbstractSet

    HashSet

    TreeSet

    是(用二叉树排序)

    Map

    AbstractMap

    使用key-value来映射和存储数据,Key必须惟一,value可以重复

    HashMap

    TreeMap

    是(用二叉树排序)

    几个面试常见问题:
    1.Q:Comparable和Comparator区别
        A:调用java.util.Collections.sort(List list)方法来进行排序的时候,List内的Object都必须实现了Comparable接口。
            java.util.Collections.sort(List list,Comparator c),可以临时声明一个Comparator 来实现排序。
            Collections.sort(imageList, new Comparator() {
                public int compare(Object a, Object b) {
                    int orderA = Integer.parseInt( ( (Image) a).getSequence());
                    int orderB = Integer.parseInt( ( (Image) b).getSequence());
                    return orderA - orderB;
               }
            });
            如果需要改变排列顺序
            改成return orderb - orderA 即可。

    4.Collection
                extends Iterable


    public interface
    List
                extends Collection


    public abstract class
    AbstractList
                extends AbstractCollection
                implements List


    public class
    Vector
                extends AbstractList
                implements List,
                                       RandomAccess,
                                       java.lang.Cloneable,
                                       java.io.Serializable
    基于Array
    是“sychronized”


    public class
    ArrayList
           
    extends AbstractList
           
    implements List,
                              RandomAccess,
                              Cloneable,
                              java.io.Serializable
    基于Array
    ArrayList非同步的。所以在性能上要比Vector优越一些


    public class
    LinkedList
            extends AbstractSequentialList
            implements List,
                              Queue,
                              Cloneable,
                              java.io.Serializable
    不基于Array

    基于ArrayListVectorArrayList)适合查询,而LinkedList(链表)适合添加,删除操作




    List基本上都是以Array为基础。但是Set则是在HashMap的基础上来实现的,这个就是SetList的根本区别
    public abstract class AbstractSet
        extends AbstractCollection
        implements Set


    public class HashSet
        extends AbstractSet
        implements Set, Cloneable, java.io.Serializable
    HashSet的存储方式是把HashMap中的Key作为Set的对应存储项


    public class LinkedHashSet
        extends HashSet
        implements Set, Cloneable, java.io.Serializable


    public class TreeSet
        extends AbstractSet
        implements SortedSet, Cloneable, java.io.Serializable
    它是通过SortedMap来实现的




    public interface Map<K,V>


    public abstract class AbstractMap<K,V>
        implements Map<K,V>


    public class HashMap<K,V>
        extends AbstractMap<K,V>
        implements Map<K,V>, Cloneable, Serializable


    public class TreeMap<K,V>
        extends AbstractMap<K,V>
        implements SortedMap<K,V>, Cloneable, java.io.Serializable

    HashMap通过hashcode对其内容进行快速查找,而TreeMap中所有的元素都保持着某种固定的顺序,如果你需要得到一个有序的结果你就应该使用TreeMap(HashMap中元素的排列顺序是不固定的)

  • 相关阅读:
    vue 零散记录
    flex布局-弹性布局
    apply 和 call 的用法
    git版本控制系统重新认识
    Windows驱动过滤--kdbclass过滤,寒江独钓加强版
    Socket的select制作多客户端传输(Qt)
    基于g_soap制作的数据下载器,传输速度只有600kb 需改进
    lua中获取数组长度问题
    MySQL存储过程详解 mysql 存储过程(转:http://blog.sina.com.cn/s/blog_52d20fbf0100ofd5.html)
    lua接受C++返回值
  • 原文地址:https://www.cnblogs.com/kaikailele/p/3875090.html
Copyright © 2011-2022 走看看