集合

   对于集合的使用上来说,工作中经常性的用到。主要用到的就是ArrayList、HashMap、Set的创建、添加元素、删除元素、遍历元素。对于集合的安全性及源码解析上不清楚。

       类图

       在查看源码的过程中发现一个有趣的现象就是接口的继承问题。在Java中类只允许继承一个类,可以实现多个接口;对于接口来说允许继承多个接口,但是只允许实现一个接口。

List的实现类的区别

ArrayList内部通过数组实现,添加元素存储空间不够时可以自动增加存储空间,此举会造成添加、删除操作的代价较高。

Vector内部通过数据实现,支持线程的同步。查看Vector源码可见实现的方法大多用Synchronized进行修饰,来达到线程同步的目的。

LinkedList采用链表结构存储数据。适合数据的动态插入和删除。不支持线程同步。

Queue的实现类

主要是队列,主要的操作有peek()取到队列头部元素但是不删除,poll是取到队列头部元素并删除。(对于队列不经常使用,联想到消息MQ对列可能会用到,可扩展研究)

Set

HashSet不允许出现重复元素,允许为null。存放元素的时候,首先调用hashcode比较已经存储的元素的hashcode与新增元素的hashcode元素是否一致,不一致则直接添加,如果一致则再equals进行比较是否相同,如果不同则进行添加,反之不添加。

 

Map的类图


Hashtable底层数据结构是哈希表结构,线程同步的,不允许非null对象

HashMap 底层是哈希表数据结构,线程不同步,允许null元素。

TreeMap  底层是二叉树数据结构,线程不同步,

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值