2021-06-01

> java集合

接胡存放在java.util包中,主要有3种:set list map
1.collection:collection是集合list set queue的最基本的接口
2.Iterator:迭代器,可以通过迭代器遍历集合中的数据
3.Mao:是映射表的基础接口
java的List集合是非常常用的数据类型,List是有序的Collection
java List一共三个实现类,分别是:ArrayList Vector LinkedList

ArrayList(数组)

ArrayList是最常用的list实现类.内部是通过数组实现的,他允许读元素进行快速随机的访问,数组的缺点是每个元素之间不能有间隔,当数组大小不满足时候需要增加存储能力.就要将已经有的数组的数据复制到新的存储空间中,当从ArrayList的中间文职插入或者删除元素时,需要对数组进行复制,.移动.代驾比较高.因此,它适合随机查找和遍历,不适合插入和删除

> Vector(数组实现,线程同步)

Vectir与ArrayList 一样.也是通过数组实现的,不同的是他的线程同步,即某一时刻只有一个线程能够写vector,避免多线程同时写而引起的不一致性,因此,访问他比访问ArrayList慢

> LinkList(链表)

LinkedList是用链表结构存储数据的,很适合数据的动态插入和删除.随机访问和遍历速度较慢,另外,他还提供了List,接口中没有定义方法,专门用于操作表头和表尾元素,可以当做堆,栈,队列和双向队列使用

Set

注重独一无二的性质,该体系集合用于存储无序元素.值不能重复,对象的相等性本质是对象HashCode值判断的,如果想要让两个不同的对象视为相等,就必须覆盖object的HashCode方法和equals方法

HashSet

哈希表存放的是哈希值,HashSet存储元素的顺序并不是按照存入时的顺序,而是按照哈希值来存的所以取数据也按照哈希值取得,元素的哈希值是通富哦元素的hashCode方法来获取的,HashSet说先判断两个元素的哈希值,如果哈希值一样,接着会比较equals方法如果equals结果Wietrue,HashSet就是为同一个元素,如果equals为false就不是 同一个元素
哈希值相同equals为false的元素是怎么存储的呢?就是再同样的哈希值下顺延,也就是哈希一样的存一列

TreeSet(二叉树)

1.TreeSet是使用二叉树的原理对新add的对象按照指定的顺序排序,将对象插入二叉树的指定位置
2.Integer和String对象都可以进行默认的TreeSet排序.而自定义类的对象是不可以的.自己定义的类必须实现Comparable接口.并且覆盖相应的compareto函数,才可以正常使用
3.在覆盖compare函数的时候,要返回相应的值才能使用TreeSet按照一定的规则来排序
4.比较此对象与指定对象的顺序,如果该对象小于,等于或大于指定对象.则分别返回负整数,零,正整数

LinkHashSet (HashSet+LinkHashMap)

对于LinkedHashSet而言,他继承HashSet,有基于LinkedHashMap来实现,LinkedHashSet底层使用LinkedHashMap,来保存所有元素,他继承HashSet,其所有方法操作上又与HashSet相同.因此LinkedHashSet的实现闪个非常简单,只提供了四个构造方法,并通过传递一个表示参数,调用父类的构造器,底层构造一个LinkedHashMap来实现.,在相关操作上与父类HashSet操作相同,直接调用父类的HashSet的方法即可

HashMap(数组 + 链表 + 红黑树)

HashMap根据键的hashCode值存储数据,大多数情况下可以直接定位到他的值,因而具有很快的访问速度,当遍历顺序却是不确定的HashMap最多只允许一条记录的键为null,允许多条记录的值为null,HashMap非线程安全,既任意时刻可以有多个线程同时写GHashMap,可能会导致数据的不一致,如果需要满足线程安全,可以用collections的synchronizedMap方法使HashMap具有线程安全的能力,或者使用concurrenHashMao.

HashMap结构

大方向上,HashMap里面是一个数组,然后数组中每一个元素是一个单项链表,嵌套类entry包含了四个元素:key value hash值和用于单向链表的next

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值