五、集合

感觉主要是应用吧,只谈概念。就那些…没有什么理解上面的难度
一、概述
集合大致可分为:set。list,map,queue这四大种。其中set无序不可重复,list有序可重复,map存储的元素是有映射关系的,queue是Java5之后的队列集合
集合像一种容器,把元素丢进去之后会丢失原来的数据类型。Java5之后新增泛型,可以解决这种问题。
主要由两个接口派生出来:Collection和Map
其中Collection派生出来的主要有Set,List,Queue。常用的几个类HashSet,TreeSet,ArrayList,ArrayQueue,LinkedList,HashMap,TreeMap等实现类
Map的有HashMap,Hashtable。HashMap线程不安全,键值对可为空。HashTable线程安全,效率相对较低,键值对值不可为空。

二、Collection和Iterator接口
Collection 对象 = new 与使用的集合类();
添加删除元素,返回Collection集合元素个数以及清空整个集合。使用System.out.println输出集合对象是整个集合中内容。
如何遍历出集合对昂:
1。Iterator接口是Collection的父接口提供了默认的forEach()方法。集合可以直接调用forEach()
对象.forEach(obj->System.out.println(obj));
2。使用Java8增强的Iterator遍历集合
主要用于遍历,不赞成修改之类的操作。。
3。使用Lambda表达式遍历
创建集合Iterator it = 集合对象.Iterator();
it.forEachRemaining(obj->System.out.println(obj));

二、Set集合
常用HashSet TreeSet EnumSet
1。HashSet 按照哈希算法来存储集合中元素,良好存取查找性能。
顺序可能与添加顺序不同
线程不同步,需要用代码来保证同步。元素值可以为null
HashSet集合判断两个值相等的标准是hashcode值相等,equals相等。HashCode方法就是HashSet集合存储高效率的原因。
如果多个元素HashCode()值相同但是equals()不同就需要在一个桶中放多个元素来降低效率。
重写hashcode要保证:多次调用HashCode的值相同。调用equals和hashcode值要相同
2。LinkedHashSet是HashSet的子类
根据元素的HashCode值来存储数据,同时使用链表来维护元素,使得元素看起来是以插入顺序来存储的。因此性能略低于HashSet。
但是迭代访问Set里面全部数据性能较好
3。TreeSet类——Sort接口的实现类,确保集合元素处于排序状态。采用红黑树的数据结构存储,支持两种排序方法
自然排序 直接compareTo(object)
定制排序(有点像之前做题用的结构体排序。。应该用的就是这个原理)
三、List集合
集合中每个元素都有索引,可以使用普通的for来遍历集合元素
1。ArrayList和Vectory实现类
向ArrayList或者Vector添加元素超过长度可以继续添加。。
2。Arrays.ArrayList是固定长度集合。程序只能遍历访问,不可以添加,删除

四、Queue模拟队列

五、Java8增强的Map集合
HashMap线程不安全的。
Hashtable 这个是个比较古老的类,从名字上就可以判断出来。名字没有遵循命名规范、线程安全的。

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READme.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 、 1资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READmE.文件(md如有),本项目仅用作交流学习参考,请切勿用于商业用途。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。
Java集合框架是Java编程中非常重要的一部分,它提供了一系列的接口和类来存储和操作数据。Java集合框架可以分为以下五个主要部分: 1. List(列表):List是一个有序的集合,允许重复元素。常用的实现类有ArrayList和LinkedList。ArrayList基于数组实现,支持快速随机访问;LinkedList基于链表实现,支持高效的插入和删除操作。 2. Set(集合):Set是一个不允许重复元素的集合,保证元素的唯一性。常用的实现类有HashSet和TreeSet。HashSet基于哈希表实现,具有较快的插入和查找速度;TreeSet基于红黑树实现,元素按照自然顺序或者自定义顺序进行排序。 3. Map(映射):Map是一种键值对的集合,每个键对应一个值。常用的实现类有HashMap和TreeMap。HashMap基于哈希表实现,根据键快速查找值;TreeMap基于红黑树实现,键按照自然顺序或者自定义顺序进行排序。 4. Queue(队列):Queue是一种先进先出(FIFO)的数据结构,常用于任务调度、消息传递等场景。常用的实现类有LinkedList和PriorityQueue。LinkedList可以作为队列或者栈使用;PriorityQueue基于堆实现,可以按照元素的优先级进行排序。 5. Deque(双端队列):Deque是一种既可以在队列头部进行插入和删除操作,也可以在队列尾部进行插入和删除操作的数据结构。常用的实现类有ArrayDeque和LinkedList。ArrayDeque基于循环数组实现,具有较高的性能;LinkedList也可以作为双端队列使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值