总结collection类

简介: 总结collection类


image.png

1.collection

collect为存储数据的集合类的顶级接口。所以不能实例化,只能实现collection,长度可变,集合为引用类型。

list和set是collection的实现类

2.list

list有序,可以重复,可以为空,实现类有ArrayList、LinkedList 和 Vector。

  1. linklist以链表的方式存储增删更快,线程不安全,效率高。
  2. arraylist以数组的方式存储,查询更快 ,效率高,线程不安全。
  3. vector线程安全,效率低,增长率为100%,数据量较大的数据

3.set

不可以重复,无序,treeset,hashset,linkhashset为set的实现类。

  1. hashset 数据结构是哈希表,按照hash值排序,不存在重复值,通过hashcode和equals判断。线程安全,存取快。
    元素的哈希值是通过元素的hashcode方法来获取的, HashSet首先判断两个元素的哈希值,如果哈希值一样,接着会比较equals方法 如果 equls结果为true ,HashSet就视为同一个元素。如果equals 为false就不是同一个元素。
    哈希值相同equals为false的元素是怎么存储呢,就是在同样的哈希值下顺延(可以认为哈希值相同的元素放在一个哈希桶中)。也就是哈希一样的存一列。
  2. treeset 可以自然排序。不可重复。
  3. LinkedHashSet 会保存插入的顺序

4.map

map是map的接口的实现类,为键值对的,包括hashmap,treemap,hashtable,linkedtreetable。

  1. hashmap 且键唯一,键 值 可为空,线程不同步。
  2. treeMap 可以对集合中的键进行排序
  3. LinkedHashMap 保存了记录的插入顺序
  4. hashtable key和value的值均不允许为null;它支持线程的同步,即任一时刻只有一个线程能写Hashtable,因此也导致了Hashtale在写入时会比较慢。

5.遍历map

iterator it = map.entry rset.interator()
while(it.hasnext()){
entry k = it..next()
syso(k.getkey(),k.getvalue)
}

6.线程安全问题

linklist arraylist hashset linkhashset线程不安全
vector hashtable为线程安全
stringbuffer为线程不安全 stringbuild为线程安全

7.总结

  1. ArrayXxx:底层数据结构是数组,查询快,增删慢
  2. LinkedXxx:底层数据结构是链表,查询慢,增删快
  3. HashXxx:底层数据结构是哈希表。依赖两个方法:hashCode()和equals()
  4. TreeXxx:底层数据结构是二叉树。两种方式排序:自然排序和比较器排序


相关文章
|
8月前
|
Java
Collection接口详解
Collection接口详解
|
5月前
|
存储 Java 索引
Collection集合
Collection集合
|
8月前
|
存储 Java BI
JavaSE&Collection集合
JavaSE&Collection集合
41 6
|
8月前
|
容器
Collection接口
Collection接口
|
8月前
|
存储 Java API
java集合Collection(List)和泛型
java集合Collection(List)和泛型
|
存储 Java
Java集合Collection
Java集合Collection
69 0
|
Java
Java集合框架Collection接口
Java集合框架是Java编程中的一个非常重要的部分,提供了一组用于处理数据集合的接口和类。其中Collection接口是Java集合框架的基础接口之一,定义了一些基本的集合操作,包括添加元素、删除元素、遍历集合等。在这里,我将为您详细介绍Java集合框架中的Collection接口。 Collection接口是Java集合框架中的基础接口,定义了一些基本的集合操作,包括添加元素、删除元素、遍历集合等。在Java中,Collection接口是一个顶层接口,它有两个主要的子接口:List和Set。其中,List是一个有序的集合,可以包含重复的元素;而Set是一个不重复的集合,元素是无序的。
95 0
|
Java
Java集合-Collection
Java集合-Collection
147 1
Java集合-Collection
|
存储 自然语言处理 安全
【JavaDS】集合Map和Set及其相关实现类
【JavaDS】集合Map和Set及其相关实现类
78 0
【JavaDS】集合Map和Set及其相关实现类
|
存储 Java
Java集合Collection类
数组在存储多个数据方面的缺点: 一旦初始化后,其长度就确定了 数组中提供的方法非常有限,对于添加、删除、插入数据等操作非常不便,同时效率不高。 获取数组中实际元素个数的需求,数组没有现成的属性或方法可用。 数组存储数据的特点:有序、可重复。对于无序、不可重复的需求不能满足。
80 0