【java】Collection集合

版权声明:可以转载奥 https://blog.csdn.net/Jiajikang_jjk/article/details/83041617

Collection集合

说明

        此篇博文是博主在学习,复习,回复自己之前学习java集合的笔记的一个总结,之前因为学习需要用到了集合以及数组,但是博主当时真的是一脸茫然,似乎感觉从来都没接触过集合,数组一样,回头翻看自己的笔记其实自己学习的广度是挺大的,只是没有深入,细化,没有完完全全,彻彻底底的理解吧,不然甚至对集合的概念都一脸茫然。写此博文,再次记录以及回顾一下。最后对自己说java坚决不能丢,必须养成每天阅读java代码的习惯。

前言

        java提供很多集合类,它们的数据结构不同,当然它们也有共性的内容(存储,获取,判断等),通俗的来说这个集合的老大就是Collection

背景

集合的由来:
 	我们学习的是面向对象语言,而面向对象语言对事物的描述是通过对象体现的,为了方便对多个对象进行操作,我们就必须把这多个对象进行存储。
 		而要想存储多个对象,就不能是一个基本的变量,而应该是一个容器类型的变量,在我们目前所学过的知识里面,有哪些是容器类型的呢?
  		数组和StringBuffer。但是呢?StringBuffer的结果是一个字符串,不一定满足我们的要求,所以我们只能选择数组,这就是对象数组。
  		而对象数组又不能适应变化的需求,因为数组的长度是固定的,这个时候,为了适应变化的需求,Java就提供了集合类供我们使用。
 
  数组和集合的区别?
 	A:长度区别
 			数组的长度固定
  			集合长度可变
 	B:内容不同
 			数组存储的是同一种类型的元素
 			而集合可以存储不同类型的元素
 
  			数组可以存储基本数据类型,也可以存储引用数据类型
  			集合只能存储引用类型
 
  刚说过集合是存储多个元的,但是呢,存储多个元素我们也是有不同需求的:比如说,我要这多个元素中不能有相同的元素,
  再比如说,我要这多个元素按照某种规则排序一下。针对不同的需求,Java就提供了不同的集合类,这样呢,Java就提供了很多个集合类。
  这多个集合类的数据结构不同,结构不同不重要的,重要的是你要能够存储东西,并且还要能够使用这些东西,比如说判断,获取等。
  既然这样,那么,这多个集合类是有共性的内容的,我们把这些集合类的共性内容不断的向上提取,最终就能形成集合的继承体系结构。
  
  数据结构:数据的存储方式。
  Collection:是集合的顶层接口,它的子体系有重复的,有唯一的,有有序的,有无序的。 

集合框架体系图

        下图就是博主画的集合体系图,通过这个图形就能够一目了然的看到java的集合是这个什么样子,以后在遇见到这样那样的集合,就不会懵逼它们之间的关系是什么样子。
在这里插入图片描述

集合的功能概述

 * Collection:是集合的顶层接口,它的子体系有重复的,有唯一的,有有序的,有无序的。(后面会慢慢的讲解)
* 
* Collection的功能概述:
* 1:添加功能
* 		boolean add(Object obj):添加一个元素
* 		boolean addAll(Collection c):添加一个集合的元素
* 2:删除功能
* 		void clear():移除所有元素
* 		boolean remove(Object o):移除一个元素
* 		boolean removeAll(Collection c):移除一个集合的元素(是一个还是所有)
* 3:判断功能
* 		boolean contains(Object o):判断集合中是否包含指定的元素
* 		boolean containsAll(Collection c):判断集合中是否包含指定的集合元素(是一个还是所有)
* 		boolean isEmpty():判断集合是否为空
* 4:获取功能
* 		Iterator<E> iterator()(重点)
* 5:长度功能
* 		int size():元素的个数
* 		面试题:数组有没有length()方法呢?字符串有没有length()方法呢?集合有没有length()方法呢?
* 6:交集功能
* 		boolean retainAll(Collection c):两个集合都有的元素?思考元素去哪了,返回的boolean又是什么意思呢?
* 7:把集合转换为数组
* 		Object[] toArray()

猜你喜欢

转载自blog.csdn.net/Jiajikang_jjk/article/details/83041617