JAVA常用数据结构

collection

java中集合都继承至collection接口。

List

元素按插入顺序保存,元素可重复。

ArrayList:Object[]数组实现,查询快,增删慢,线程不安全。

LinkedList:Node双向链表实现(头结点为first),查询慢(要移动指针),增删快,线程不安全。

Vector:矢量数组/向量,Object[]数组实现,查询快,增删慢,线程同步(方法加锁)。

Stack:继承至Vector,先进后出。

 

Set

顺序和元素的hash值有关,元素唯一。

HashSet:内部是HashMap,只使用到key部分,value为一个固定的 Object PRESENT = new Object();可以为null,线程不安全。

LinkedHashSet:继承至HashSet,线程不安全。

TreeSet:内部是TreeMap,原理和HashSet类似,红黑树树实现,元素唯一,自动排序,不能为null。

 

Map

HashMap:底层hash表(散列表,hash数组,Node<K,V>[] table,key,value可以为null。

Node实现了Map.Entry<K,V>接口),线程不安全,数组里的每个元素(key-value)都是一个单链表的头节点,链表是用来解决hash冲突的。

        通过元素的hash值和equals方法判断唯一性的:元素的hash值(执行hash函数后得到的值)不同,直接存到哈希表,如果相同(有多个则要遍历判断每一个)判断元素的equals是否为true,如果为true视为相同元素,不存,为false视为不同元素,存储(放在node节点下,多个则要放尾节点下)。

      扩容后的链表顺序和原来相反(头插法,减少一次循环次数),多线程下扩容过程中可能出现死锁:线程1准备处理节点,线程2把HashMap扩容成功,链表已经逆向排序,那么线程1再处理节点时就可能出现环形链表形成死循环。jkd1.8+版本中,链表元素超过8就会转为TreeNode(红黑树)

LinkedHashMap:继承至HashMap,双向链表(Entry<K,V> before, after;Entry<K,V> 继承至HashMap.Node<K,V> )。

HashTable:内部实现和hashMap相同(Entry<?,?>[] table),区别在于线程安全(方法上加锁),key,value都不能为null。

TreeMap:顶节点是Entry<K,V> root(实现了Map.Entry<K,V>接口,每个对象保存三个节点引用,当前,左,右以及是否为黑的属性),红黑树对所有key排序,不能为null。

 

==    :基本类型变量,直接比较存‘值’是否相等,引用类型变量比较所指向对象的地址。

equals:默认(==)比较的是两个引用类型变量所指向的对象的地址,字符串比较值。

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值