Java数据结构总览

Java数据结构总览

前言:以Java为基础,对数据结构进行总览。

java.util 包提供了丰富的数据结构实现(9类):数组(Arrays)、列表(Lists)、集合(Sets)、映射(Maps)、栈(Stack)、队列(Queue)、堆(Heap)、树(Trees)、图(Graphs)。

1 Java集合框架

主要分为两类:Collection 和 Map。Collection主要用于存储一组对象,Map用于存储键值对
Collection接口:
在这里插入图片描述
Map接口:
在这里插入图片描述
总览:
在这里插入图片描述
Collection 接口有 3 种子类型,List、Set 和 Queue,再下面是一些抽象类,最后是具体实现类,常用的有 ArrayList、LinkedList、HashSet、LinkedHashSet、HashMap、LinkedHashMap 等等。该框架也定义了几个 Map 接口和类。Map 里存储的是键/值对。尽管 Map 不是集合,但是它们完全整合在集合中

1.1 集合接口(部分)

序号接口描述
1Collection 接口
Collection 是最基本的集合接口,一个 Collection 代表一组 Object,即 Collection 的元素, Java不提供直接继承自Collection的类,只提供继承于的子接口(如List和set)。
Collection 接口存储一组不唯一无序的对象。
2List 接口
List接口是一个有序的 Collection,使用此接口能够精确的控制每个元素插入的位置,能够通过索引来访问List中的元素,第一个元素的索引为 0,而且允许有相同的元素。
List 接口存储一组不唯一有序的对象。
3Set接口
Set 具有与 Collection 完全一样的接口,只是行为上不同,Set 不保存重复的元素。
Set 接口存储一组唯一无序的对象。
4Map接口
Map 接口存储一组键值对象,提供key(键)到value(值)的映射。
5Map.Entry接口
描述在一个Map中的一个元素(键/值对)。是一个 Map 的内部接口。
6SortedMap接口
继承于 Map,使 Key 保持在升序排列。

Set和List的区别

  1. Set 接口实例存储的是无序的,不重复的数据。List 接口实例存储的是有序的,可以重复的元素。

  2. Set 检索效率低删除和插入效率高,插入和删除不会引起元素位置改变 <实现类有HashSet,TreeSet>。

  3. List 可以动态增长,根据实际存储的数据的长度自动增长 List 的长度。查找元素效率高插入删除效率低,因为会引起其他元素位置改变 <实现类有ArrayList,LinkedList,Vector> 。

1.2 集合实现类(部分)

序号接口描述
1LinkedList
该类实现了List接口允许有null元素。主要用于创建链表数据结构,该类没有同步方法,如果多个线程同时访问一个List,则必须自己实现访问同步,解决方法就是在创建List时候构造一个同步的List。
2ArrayList
该类也是实现了List的接口,实现了可变大小的数组,随机访问和遍历元素时,提供更好的性能。该类也是非同步的,在多线程的情况下不要使用。ArrayList 增长当前长度的50%,插入删除效率低。
3HashSet
该类实现了Set接口,不允许出现重复元素,不保证集合中元素的顺序,允许包含值为null的元素,但最多只能一个。
4HashMap
HashMap 是一个散列表,它存储的内容是键值对映射。
该类实现了Map接口,根据键的HashCode值存储数据,具有很快的访问速度,最多允许一条记录的键为null,不支持线程同步

java.util包中定义的类,如下所示:

序号接口描述
1Vector
该类和ArrayList非常相似,但是该类是同步的,可以用在多线程的情况,该类允许设置默认的增长长度,默认扩容方式为原来的2倍
2Stack
是Vector的一个子类,它实现了一个标准的后进先出的栈。
3Dictionary
Dictionary 类是一个抽象类,用来存储键/值对,作用和Map类相似。
4Hashtable
Hashtable 是 Dictionary类的子类,位于 java.util 包中。
5Properties
Properties 继承于 Hashtable,表示一个持久的属性集,属性列表中每个键及其对应都是一个字符串
6BitSet
一个Bitset类创建一种特殊类型的数组来保存位值。BitSet中数组大小会随需要增加。

1.3 迭代器

迭代器可以遍历集合框架,它是一个对象,实现了Iterator 接口或 ListIterator接口。ListIterator 继承了 Iterator,以允许双向遍历列表和修改元素。

1.4 比较器

比较器可以让我们以不同的方式来排序一个集合。

2 总结

Java集合框架为程序员提供了预先包装的数据结构和算法来操纵他们。
集合是一个对象,可容纳其他对象的引用。集合接口声明对每一种类型的集合可以执行的操作。
集合框架的类和接口均在java.util包中。
任何对象加入集合类后,自动转变为Object类型,所以在取出的时候,需要进行强制类型转换。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值