Java基础之集合

集合简介

本文基于JDK1.7梳理Java中集合的整体结构。
集合是Java开发中使用最多的,主要涉及到的知识可以概括为数据结构、查找算法;根据适用场景不同,演进出不同的集合类实现。在多线程的环境下,又有了线程安全和不安全的区别。

集合层次结构

先上两张集合的继承和实现关系图:
Collection

Map
Java中的集合都起源于 java.util. Collection和java.util.Map这个两个接口。Collection用于保存单个的元素,Map用于存放键-值(K-V)数据,能够通过”键”找到对应的”值”。
从Collection继承来的有Queue、List、Set三个接口。

接口特征主要实现
Queue数据有先后顺序,遵循先进先出(FIFO)的原则ArrayBlockingQueue、LinkedBlockingQueue
List数据有序、可重复、可索引LinkedList、ArrayList、SortedList
Set数据无顺序、不能重复HashSet、TreeSet、LinkedHashSet

Queue

队列是一种基本的数据结构,包含两种操作:

 1. 在队列尾添加一个元素
 2. 从队列头取出一个元素。

Queue接口中定义的基本方法如下:

方法功能描述
add()在队列尾部插入一个元素,如果队列空间不足,抛出IllegalStateException
offer()在队列尾部插入一个元素,队列空间不足时返回false
remove()从队列头取出一个元素,并删除它
poll()从队列头取出一个元素,并删除它
element()从队列头取出一个元素,但是不删除这个元素
peek()从队列头取出一个元素,但是不删除这个元素

下面是AbstractQueue中add方法的代码,可以发现为了方便开发人员,对于队列每种操作,JDK都提供了两个方法,它们的区别仅在于失败时是否抛出异常。开发时根据业务场景需求,使用合适的方法就好。

    public boolean add(E e) {
        if (offer(e))
            return true;
        else
            throw new IllegalStateException("Queue full");
    }

队列具体的实现类,分为了两大阻塞队列和非阻塞队列两大类;

数据结构

List

SET

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值