容器框架学习

在JDK8中rt.jar文件中,java.util.*包中的容器主要包括List、Set、Queue和Map四大类,其中List、Set、Queue是和Collection接口相关的容器,而Map是单独列出来的容器。


类图.png
  • Collection是最基本的集合接口,一个Collection代表一组Object,即Collection的元素(Element)。一些Collection允许相同的元素而另一些不行。一些能排序而另一些不行。Java SDK不提供直接继承自Collection的类JavaSDK提供的类都是继承自Collection的子接口,如List和Set。
  • 所有实现Collection接口的类都必须提供两个标准的构造函数:无参数的构造函数用于构建一个空的Collection,有一个Collection的参数的构造函数用于创建一个新的Collection,这个新的Collection与传入的Collection有相同的元素。后一个构造函数允许用户复制一个Collection。
  • 如何遍历Collection中的每一个元素?
    • 不论Collection的实际类型如何,它都支持一个iterator()的方法,该方法返回一个对象,使用该迭代对象即可逐一访问Collection中每一个元素。典型用法如下:
Iterator it = collection.iterator();//获得一个迭代对象
    while(it.hasNext()){
Object obj = it.next();//得到下一个对象
}

具体

  • Set集合
    • Set集合是最简单的集合,集合中的对象不按照特定的方式排序。主要有:HashSet()和TreeSet().
  • HashSet
    • HashSet类按照哈希算法来存取集合中的对象,具有很好的存取性能。当HashSet向集合中加入一个对象时,会调用对象的HashCode()方法获取哈希码,然后根据这个哈希码进一步计算出对象在集合中的存放位置。
  • TreeSet实现了SortedSet接口可以对集合中的元素排序。

List集合

  • List继承自Collection接口。List是一种有序集合,List中的元素可以根据索引(顺序号:元素在集合中处于的位置信息) 进行取得/删除/插入操作。
    跟Set集合不同的是,List允许有重复元素。对于满足e1.equals(e2)条件的e1与e2对象元素,可以同时存在于List集合中。当然,也有List的实现类不允许重复元素的存在。同时,List还提供一个listIterator()方法,返回一个ListIterator接口对象,和Iterator接口相比,ListIterator添加元素的添加,删除,和设定等方法,还能向前或向后遍历,具体的方法往下看。List接口的实现类主要有ArrayList,LinkedList,Vector,Stack等。

List算法

Explanation Name
使用合并排序算法排序List,默认为升序排列 sort
使用随机源对指定列表进行置换 shuffle
反转指定列表中元素的顺序 reverse
根据指定的距离轮换指定列表中的元素 rotate
交换指定位置上的元素 swap
使用一个值替换列表中出现的所有某一指定值 replaceAll
使用指定元素替换列表中的所有元素 fill
将所有元素从一个列表复制到另一个列表 copy
使用二分搜索指定列表,以获得指定对象 binarySearch
返回指定列表中第一次出现指定目标列表的起始位置;如果没有这样的目标则返回-1. indexOfSubList
返回指定列表中最后一次出现指定目标列表的起始位置;如果没有这样的目标则返回-1 lastIndexOfSubList

ArrayList

  • ArrayList实现了可变大小的数组。它允许所有元素,包括null。ArrayList没有同步。size、isEmpty、get、set方法运行时间为常数。但是add方法开销为分摊的常数,添加n个元素需要O(n)的时间。其他的方法运行时间为线性。

    每个ArrayList实例都有一个容量(Capacity),即用于存储元素的数组大小。这个容量可随着不断添加新元素而自动增加,但是增长算法并没有定义。当需要插入大量元素时,在插入前可以调用ensureCapacity方法来增加ArrayList的容量以提高插入效率。

  • 主要方法:

Function Explanation
public boolean add(E e) 添加元素
Public void add(int index,E element) 在指定位置添加元素
public Iterator<E> iterator() 取得Iterator对象便于遍历所有元素
public E get(int index) 根据索引获取指定位置的元素
public E set(int index,E element) 替换掉指定位置的元素
  • 排序方法
Functiom Explanation
Collections.sort(java.util.List<T>) 对List的元素进行自然排序
Collections.sort(java.util.List<T>,java.util.Comparator<? super T>) 对List中的元素进行自定义排序

LinkedList

LinkedList实现了List接口,允许null元素。此外LinkedList提供额外的get,remove,insert方法在LinkedList的首部或尾部。这些操作使LinkedList可被用作堆栈(stack),队列(queue)或双向队列(deque)。

<font color=red>注意LinkedList没有同步方法。如果多个线程同时访问一个List,则必须自己实现访问同步。一种解决方法是在创建List时构造一个同步的List:</font>

List list = Collections.synchronizedList(new LinkedList(...));
Map.jpg

Map

  • Map是一种把键对象和值对象进行映射的集合,它的每一个元素都包含一堆键对象和值对象;
  • 向Map添加元素时,必须提供键对象和值对象;
  • 从Map中检索元素时,只要给出键对象,就可以返回对应的值对象;
  • 键对象不能重复,但值对象可以重复;
  • Map有两种常见的实现类:HashMap和TreeMap。
Function Explanation
V put(K key,V value) 插入元素
V get(Object key) 根据键对象获取值对象
Set<K> KeySet() 取得所有键对象集合
Collection<V> values() 取得所有值对象集合
Set<Map.Entity<K,V>> entrySet() 取得Map.Entry代表一个Map中的元素

HashMap

HashMap按照哈希算法来存取键对象,有很好的存取性能。和HashSet一样,要求当两个键对象通过equals()方法比较为true时,这两个键对象的hashCode()方法返回的哈希码也一样。

HashCode:

  1. HashCode的存在主要是用于<font color=red>查找的快捷性</font>,如Hashtable,HashMap,等,HashCode经藏用语确定对象的存储地址
  2. 如果两个对象相同,equals方法一定返回true,并且这两个对象的HashCode一定相同
  3. <font color=red>两个对象的HashCode相同,并不一定表示两个对象就相同</font>,即equals()不一定为true,只能说明这两个对象在一个散列存储结构中
  4. <font color=red>如果对象的equals()方法被重写,那么对象的HashCode也尽量重写</font>
  • 作用:

    从Object的角度看,JVM每new一个Object,它都会将这个Object怼到一个Hash表中去,这样的话,下次做Object的比较或者取这个对象的时候(读取过程),它会根据对象的HashCode再从Hash表中取这个对象。这样做的目的是\color{red}{提高对象的效率}。若HashCode相同再去调用equal。

TreeMap

TreeMap实现了SortedMap接口,能对键对象进行排序。同TreeSet一样,TreeMap也支持自然排序和客户化排序两种方式。

如果涉及到堆栈,队列等操作,应该考虑用List,对于需要快速插入,删除元素,应该使用LinkedList,如果需要快速随机访问元素,应该使用ArrayList。尽量返回接口而非实际的类型,如返回List而非ArrayList,这样如果以后需要将ArrayList换成LinkedList时,客户端代码不用改变。这就是针对抽象编程。

\color{red}{LinkedList}

Interface Iterable<T>

  • The functions forEach() and spliterator() both use a keword “default” which means we could provide the default implement in an abstruct class,breaking the previous rule in JAVA.

<font color=blue>JDK8 Functional interface</font>

Function Explanation
Function<T,R> accept a parameter and return a result
Consumer<T> accept a parameter without result returned
Predicate<T> accept a parameter and return a boolean result
Supplier<T> without parameter and one result returned

remark1:

  1. Three methods

    1.1 The only abstract method

    1.2 use default to define general methods, invoking through an instance.

    1.3 use static define static methods, invoking through interface name.

  2. a new annotation

    if some interface is functional interface ,then making it has only one abstract method when defining.So there is a new annonation:

    @FunctionInterface

remark2(lambda expression):

<font color=blue>use anonymous inner class to impement an interface:</font>

Function<Integer,String> fun = new Function<Integer,String>(){
  @Override
  public String apply(Integer t){
        return String.valueOf(t);
  }
}

<font color=blue>use lambda expression to implement:</font>

Function<Integer,string> -> (t){String.valueOf(t);}

Collection<E> extends Iterable<E>

  • \color{blue}{Int size()}

    • if the collection contains more than Integer.MAX_VALUE elements, returns Integer.MAX_VALUE, otherwise return the number of elements in it.
  • \color{blue}{boolean isEmpty()};

    • if the collection empty, return true;
  • <font color=blue>boolean contains(Object o)</font>

    • return ture if the collection contain the specified element.
  • \color{blue}{Iterator<E> iterator()}

    • return an iterator over the elements in the collection, unless provide a guarantee itself, there are no guarantee concerning the order in which the elements are returned.
  • \color{blue}{Object[] toArray();}

    • returns am array containing all of the elements in this collection.
  • \color{blue}{<T> T[] toArray(T[] a);}

    • Params:
      • a: the array into which the elements of this collection are to stored,if it is big enough; otherwise. a new array of the same runtime type is allocated for this purpose.If the collecition fits in the specified array with room to spare, the element in the array immediately following the end of the collection is set to null.
    • Returns:
      • an array containing all of the elements in this collection.
  • \color{blue}{boolean add(E e);}

    • return true if operation successful;
  • <font color=blue>boolean remove(Object o)</font>

  • <font color=blue>boolean containsAll(Collection<?> c);</font>

    • return true if this collection contains all of the elements in the specified collection.
  • <font color=blue>boolean addAll(Collection<? extends E> c);</font>

  • <font color=blue>boolean removeAll(Collection<?> c);</font>

  • <font color=blue>default boolean removeIf(Predicate<? super E> filter){...}</font>

    • Removes all of the elements of this collection that satisfy the given predicate.
    • true if any elements were removed.
  • <font color=blue>boolean retainAll(Collection<?> c);</font>

    • Removes from this collection all of its elements that are not contained in the specified collection.
  • <font color=blue>void clear();</font>

    • Removes all of the elements from this collection.The collection will be empty after this methods returns.
  • <font color=blue>boolean equals(Object o);</font>

    • <font color=red>Attention: if implements the Controller interface ”directly“ , must exercise care if if they choose to override the Object.equals.(When need compare the value instead of inference)</font>
    • returns true if the specified object is equals to this collection.
  • <font color=blue>int hashCode();</font>

    • <font color=red>Attention:if override the method Object.equals then must override Object.hashCode()</font>(because of hashcode contract)
    • Returns the hashcode of the collection
  • <font color=blue>default Spliterator<E> spliterator(){...}</font>

    • Creates a Spliterator over the elements in this collection.
      • Spliterator: always used with steam to traverse and divide sequential.
  • <font color=blue>default Stream<E> stream() {...}</font>

    • Returns a sequential Stream with this collection as its source.
  • <font color=blue>default Stream<E> parallelStream() {...}</font>

    • Returns a possibly parallel Stream with this collection as its source. It is allowable for this method to return a sequential stream.

List<E> extends Collection<E>

  • <font color=blue>boolean addAll(int index,Collection<? extends E> c);</font>

    • Inserts all of the elements in the specified collection into this list at the specified position.
  • <font color=blue>boolean retainAll(Collection<?> c)</font>

    • Retains only the elements in this list that are contained in the specified collection.
  • <font color=blue>default void replaceAll(UnaryOperator<E> operator){...}</font>

    • Replaces each element of the list with the result of applying the operator to that element.
  • <font color=blue>default void sort(Comparator<? super E> c){...}</font>

    • sorts this list according to the order induced by the specified Comparator.
  • <font color=blue>E set(int index, E element);</font>

    • replace the element at the specified position in this list with the specified element.
    • returns the element previously at the specified position.
  • <font color=blue>E get(int index)</font>

    • reurns the element at the specified position.
  • <font color=blue>int indexOf(Object o);</font>

    • Returns the index of the last occurrence of the specified element in this list, or -1 if this list does not contain the element.
  • <font color=blue>int lastIndexOf(Object o);</font>

    • Returns the index of the last occurrence of the specified element in this list , or -1 if there is no such index.
  • <font color=blue>ListIterator<E> listIterator();</font>

    • returns a list iterator over the elements in this list(in proper sequence).
  • <font color=blue>ListIterator<E> listIterator(int index);</font>

    • Returns a list iterator over the elements in this list, starting at the specified position in the list.
  • <font color=blue>List<E> subList(int fromIndex,int toIndex);</font>

    • returns a view of portion of this list between the specified fromIndex, inclusive,and toIndex, exclusive.(If fromIndex and toIndex are equal, the returned list is empty).

AbstractList<E> extends AbstractCollection<E> implements list<E>

Transient: the key word to avoid serializable;

checkForComodification();

used to realize fail-fast mechanism.

There are two threads, one is for traversing the list and another is for modifying the list.Sometimes thread A is traversing the list(at this moment expectedModCount=modCount=N), meanwhile thread B adds an element leading to the value of modCount modified(modCount+1=N+1). Method checkForComodification find that expectedModCunt=N, while modCount=N+1 which means two values are not equal, so the ConcurrentModificationException are throwed out and fail-fast mechanism happened.

cursor:the index of next element

lastRet:the index of last element

  • <font color=blue>public List<E> subList(int fromIndex, int toIndex)</font>
public List<E> subList(int fromIndex,int toIndex) {
  return (this instance of RandomAccess? new RandomAccessSubList<>(this,fromIndex, toIndex):new SubList<>(this, fromIndex, toIndex));
}
public interface RandomAccess{}

RandomAccess is an empty interface to identify some class backing random access or not. A class that backing random access aparently could use a more efficient arithmetic.

  • classes realized random access:
    • ArrayList
    • AttributeList
    • CopyOnWriteArrayList
    • Vector
    • Stack
    • Etc...
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,588评论 6 496
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,456评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,146评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,387评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,481评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,510评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,522评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,296评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,745评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,039评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,202评论 1 343
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,901评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,538评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,165评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,415评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,081评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,085评论 2 352

推荐阅读更多精彩内容

  • 按照从构造方法->常用API(增、删、改、查)的顺序来阅读源码,并做简要分析。 一. 定义 介绍 继承了Abstr...
    stoneyang94阅读 180评论 0 0
  • 转载自:Java集合框架实例 1- 介绍 集合是程序和语言的基本思想。应用程序通常都会应用到集合,例如雇员的信息,...
    01_小小鱼_01阅读 394评论 0 1
  • 按照从构造方法->常用API(增、删、改、查)的顺序来阅读源码,并会讲解阅读方法中涉及的一些变量的意义。 Arra...
    stoneyang94阅读 233评论 0 3
  • 持有对象 11.1泛型和类型安全的容器 11.2基本概念 Collection.一个独立元素的序列,这些元素都服从...
    zhuofai阅读 331评论 0 0
  • Java 语言支持的类型分为两类:基本类型和引用类型。整型(byte 1, short 2, int 4, lon...
    xiaogmail阅读 1,346评论 0 10