Java基础系列--08_集合1
---恢复内容开始---
集合当中有很多都是应用到泛型的技术,所以在讲集合之前,应该先将泛型的概念普及一下。
泛型:
(1)泛型是一种类型,但是这种类型是在编译或者调用方法时才确定。
(2)格式:
<数据类型> 如:Collection<E>这里的E指的是任意类型,可以理解为Object类型,因为Object是所有类的根类
(3)好处:
A:把运行期间的转换异常给提前到了编译期间
B:优化了程序设计,不需要强制类型转换
C:在减少了代码量的同时还增强了程序的可拓展性
(4)泛型的演变
A:泛型类(尤其是在C++中有很多的模板类,其实就是Java中的泛型)
B:泛型方法
C:泛型接口
(5)泛型的使用:
API中的类或者接口,其跟有<E>,就是泛型的应用。
一般在集合中用集合 (1)可以对多个对象进行存储,方便我们对多个对象的操作
(2)集合的特点:
1、长度可以发生改变
2、只能存储对象
3、可以存储多种类型对象(一般存储的还是同一种)
(3)集合和数组的区别
1、长度问题 数组固定;集合可变
2、存储元素问题
数组可以是基本类型,也可以是引用类型。
集合只能是引用类型。
3、是否同一类型
数组元素类型一致。
集合元素类型可以不一致。(在生成集合对象的时候不指定类型)
(4)集合体系的由来
集合是存储多个元素的容器,但是,由于数据结构不同,java就提供了多种集合类。
而这多种集合类有共性的功能,所以,通过不断的向上抽取,最终形成了集合体系结构。

集合的特点:
Collection 一次存一个对象, 单列集合
List 可重复, 有索引,有序
ArrayList 数组实现, 查找快, 线程不安全
LinkedList 链表实现, 增删快, 线程不安全
Vector 数组实现, 线程安全
Set 不可重复, 没索引,无序
HashSet 使用哈希算法去重复, 效率高, 但元素无序
TreeSet TreeSet是用排序的, 可以指定一个顺序, 对象存入之后会按照指定的顺序排列
LinkedHashSet HashSet的子类, 原理相同, 除了去重复之外还能保留存储顺序
这里先介绍集合的抽象类,而其抽象类提供的方法其实就是大部分需要用到的功能。学会了父类,再去学习其字类的功能,就会快很多了,因为子类拓展的功能其实并不多。这里所介绍的六个具体实现类只是其中比较常用的,还有很多其他实现类,有兴趣的朋友可以通过API去查看。
---恢复内容结束---
集合当中有很多都是应用到泛型的技术,所以在讲集合之前,应该先将泛型的概念普及一下。
泛型:
(1)泛型是一种类型,但是这种类型是在编译或者调用方法时才确定。
(2)格式:
<数据类型> 如:Collection<E>这里的E指的是任意类型,可以理解为Object类型,因为Object是所有类的根类
(3)好处:
A:把运行期间的转换异常给提前到了编译期间
B:优化了程序设计,不需要强制类型转换
C:在减少了代码量的同时还增强了程序的可拓展性
(4)泛型的演变
A:泛型类(尤其是在C++中有很多的模板类,其实就是Java中的泛型)
B:泛型方法
C:泛型接口
(5)泛型的使用:
API中的类或者接口,其跟有<E>,就是泛型的应用。
一般在集合中用集合 (1)可以对多个对象进行存储,方便我们对多个对象的操作
(2)集合的特点:
1、长度可以发生改变
2、只能存储对象
3、可以存储多种类型对象(一般存储的还是同一种)
(3)集合和数组的区别
1、长度问题 数组固定;集合可变
2、存储元素问题
数组可以是基本类型,也可以是引用类型。
集合只能是引用类型。
3、是否同一类型
数组元素类型一致。
集合元素类型可以不一致。(在生成集合对象的时候不指定类型)
(4)集合体系的由来
集合是存储多个元素的容器,但是,由于数据结构不同,java就提供了多种集合类。
而这多种集合类有共性的功能,所以,通过不断的向上抽取,最终形成了集合体系结构。

集合的特点:
Collection 一次存一个对象, 单列集合
List 可重复, 有索引,有序
ArrayList 数组实现, 查找快, 线程不安全
LinkedList 链表实现, 增删快, 线程不安全
Vector 数组实现, 线程安全
Set 不可重复, 没索引,无序
HashSet 使用哈希算法去重复, 效率高, 但元素无序
TreeSet TreeSet是用排序的, 可以指定一个顺序, 对象存入之后会按照指定的顺序排列
LinkedHashSet HashSet的子类, 原理相同, 除了去重复之外还能保留存储顺序
这里先介绍集合的抽象类,而其抽象类提供的方法其实就是大部分需要用到的功能。学会了父类,再去学习其字类的功能,就会快很多了,因为子类拓展的功能其实并不多。这里所介绍的六个具体实现类只是其中比较常用的,还有很多其他实现类,有兴趣的朋友可以通过API去查看。
Java基础系列--08_集合1的更多相关文章
- Java基础系列7——集合系列(1)框架概述
该系列博文会告诉你如何从入门到进阶,一步步地学习Java基础知识,并上手进行实战,接着了解每个Java知识点背后的实现原理,更完整地了解整个Java技术体系,形成自己的知识框架. 集合框架概述 Jav ...
- Java基础系列--ArrayList集合
原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/8494618.html 一.概述 ArrayList是Java集合体系中最常使用,也是最简单 ...
- Java基础系列--09_集合2
昨天介绍了集合的主要架构体系,今天主要的目的是学习集合的迭代器的遍历和List的特有功能. 迭代器: 概述:由于多种集合的数据结构不同,所以存储方式不同,取出方式也不同.但是他们都是有判断和获 ...
- Java多线程系列--“JUC集合”02之 CopyOnWriteArrayList
概要 本章是"JUC系列"的CopyOnWriteArrayList篇.接下来,会先对CopyOnWriteArrayList进行基本介绍,然后再说明它的原理,接着通过代码去分析, ...
- Java多线程系列--“JUC集合”03之 CopyOnWriteArraySet
概要 本章是JUC系列中的CopyOnWriteArraySet篇.接下来,会先对CopyOnWriteArraySet进行基本介绍,然后再说明它的原理,接着通过代码去分析,最后通过示例更进一步的了解 ...
- Java基础系列-ArrayList
原创文章,转载请标注出处:<Java基础系列-ArrayList> 一.概述 ArrayList底层使用的是数组.是List的可变数组实现,这里的可变是针对List而言,而不是底层数组. ...
- Java基础系列-Collector和Collectors
原创作品,可以转载,但是请标注出处地址:https://www.cnblogs.com/V1haoge/p/10748925.html 一.概述 Collector是专门用来作为Stream的coll ...
- Java基础系列-equals方法和hashCode方法
原创文章,转载请标注出处:<Java基础系列-equals方法和hashCode方法> 概述 equals方法和hashCode方法都是有Object类定义的. publi ...
- Java基础系列-Comparable和Comparator
原创文章,转载请标注出处:<Java基础系列-Comparable和Comparator> 一.概述 Java中的排序是由Comparable和Comparator这两个接 ...
随机推荐
- Golang随机数生成
需求:10以内随机生成2个幸运数字 package main import ( "fmt" "math/rand" ) func main() { fmt.Pr ...
- Ambari:Provide ability to apply single patches on top of RU release
https://issues.apache.org/jira/browse/AMBARI-12556 Provide ability to apply single patches on top of ...
- 【干货】快速部署微软开源GPU管理利器: OpenPAI
[干货]快速部署微软开源GPU管理利器: OpenPAI 介绍 不管是机器学习的老手,还是入门的新人,都应该装备上尽可能强大的算力.除此之外,还要压榨出硬件的所有潜力来加快模型训练.OpenPAI作为 ...
- pandas 获取数据帧DataFrame的行、列数
1.创建数据帧 import pandas as pd df = pd.DataFrame([[1, 'A', '3%' ], [2, 'B']], index=['row_0', 'row_1'], ...
- Android开发:UI相关(一)自定义样式资源
一.自定义样式资源: 1.在drawble中新建xml资源文件: 如果新建的xml文件没有自动放置在drawable文件夹下,就手动移动到drawable下. 2.编写样式代码: < ...
- python --- 二分查找算法
二分查找法:在我的理解中这个查找方法为什么会叫二分呢,我认为是将要查询的一个列表分成了两份,然后在利用某个值来进行比较,在一个不断循环的过程中来找出我们要找的某一个值. 废话不多说,先上代码: def ...
- 从壹开始微服务 [ DDD ] 之二 ║ DDD入门 & 项目结构粗搭建
前言 哈喽大家好,今天是周二,我们的DDD系列文章今天正式开始讲解,我这两天一直在学习,也一直在思考如何才能把这一个系列给合理的传递给大家,并且达到学习的目的,还没有特别好的路线,只是一个大概的模糊的 ...
- Java的二分搜索树
定义 二分搜索树是二叉树(不包含重复元素). 二分搜索树的每个节点的值,大于左子树的所有节点的值,小于其右子树的所有节点的值. 每一棵子树也是二分搜索树. 二叉树搜索树必须要有比较,继承Compara ...
- Vue 进阶之路(一)
vue 3.x 马上就要问世了,显然尤大大是不想让我们好好活了,但是转念一想,比你优秀的人都还在努力,那我们努力还有什么用,开个玩笑而已,本人对于 vue 的接触时间不长,对其也没有深入地去研究源码, ...
- springboot~内嵌redis的使用
对于单元测试来说,我们应该让它尽量保持单一环境,不要与网络资源相通讯,这样可以保证测试的稳定性与客观性,对于springboot这个框架来说,它集成了单元测试JUNIT,同时在设计项目时,你可以使用多 ...