1. 什么是容器
在java当中,有一个类专门用来存放其它类的对象,这个类就叫做容器,它就是将若干性质相同或相近的类对象组合在一起而形成的一个整体 。
几种常见容器介绍:
java学习视频教程推荐:java教学视频
1. list
有序的 collection(也称为序列)。此接口的用户可以对列表中每个元素的插入位置进行精确地控制。用户可以根据元素的整数索引(在列表中的位置)访问元素,并搜索列表中的元素。与 set 不同,列表通常允许重复的元素。
arraylist: object数组
vector: object数组
linkedlist: 双向链表(jdk1.6之前为循环链表,jdk1.7取消了循环)
2. set
一个不包含重复元素的 collection。更确切地讲,set 不包含满足 e1.equals(e2) 的元素对 e1 和 e2,并且最多包含一个 null 元素。正如其名称所暗示的,此接口模仿了数学上的 set 抽象。
hashset(无序,唯一): 基于 hashmap 实现的,底层采用 hashmap 来保存元素。
linkedhashset: linkedhashset 继承与 hashset,并且其内部是通过 linkedhashmap 来实现的。
linkedhashmap 其内部是基于 hashmap 实现一样,不过还是有一点点区别的。
treeset(有序,唯一): 红黑树(自平衡的排序二叉树)。
3. map
将键映射到值的对象。一个映射不能包含重复的键;每个键最多只能映射到一个值。
hashmap: jdk1.8之前hashmap由数组+链表组成的,数组是hashmap的主体,链表则是主要为了解决哈希冲突而存在的(“拉链法”解决冲突)。jdk1.8以后在解决哈希冲突时有了较大的变化,当链表长度大于阈值(默认为8)时,将链表转化为红黑树,以减少搜索时间
linkedhashmap: linkedhashmap 继承自 hashmap,所以它的底层仍然是基于拉链式散列结构即由数组和链表或红黑树组成。
另外,linkedhashmap 在上面结构的基础上,增加了一条双向链表,使得上面的结构可以保持键值对的插入顺序。同时通过对链表进行相应的操作,实现了访问顺序相关逻辑。
hashtable: 数组+链表组成的,数组是 hashmap 的主体,链表则是主要为了解决哈希冲突而存在的。
treemap: 红黑树(自平衡的排序二叉树)
4. queue
在处理元素前用于保存元素的collection。除了基本的 collection 操作外,队列还提供其他的插入、提取和检查操作。
相关文章教程推荐:java语言入门
以上就是java中的容器是指什么的详细内容。