---恢复内容开始---

集合当中有很多都是应用到泛型的技术,所以在讲集合之前,应该先将泛型的概念普及一下。

泛型:
    (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的更多相关文章

  1. Java基础系列7——集合系列(1)框架概述

    该系列博文会告诉你如何从入门到进阶,一步步地学习Java基础知识,并上手进行实战,接着了解每个Java知识点背后的实现原理,更完整地了解整个Java技术体系,形成自己的知识框架. 集合框架概述 Jav ...

  2. Java基础系列--ArrayList集合

    原创作品,可以转载,但是请标注出处地址:http://www.cnblogs.com/V1haoge/p/8494618.html 一.概述 ArrayList是Java集合体系中最常使用,也是最简单 ...

  3. Java基础系列--09_集合2

    昨天介绍了集合的主要架构体系,今天主要的目的是学习集合的迭代器的遍历和List的特有功能. 迭代器:     概述:由于多种集合的数据结构不同,所以存储方式不同,取出方式也不同.但是他们都是有判断和获 ...

  4. Java多线程系列--“JUC集合”02之 CopyOnWriteArrayList

    概要 本章是"JUC系列"的CopyOnWriteArrayList篇.接下来,会先对CopyOnWriteArrayList进行基本介绍,然后再说明它的原理,接着通过代码去分析, ...

  5. Java多线程系列--“JUC集合”03之 CopyOnWriteArraySet

    概要 本章是JUC系列中的CopyOnWriteArraySet篇.接下来,会先对CopyOnWriteArraySet进行基本介绍,然后再说明它的原理,接着通过代码去分析,最后通过示例更进一步的了解 ...

  6. Java基础系列-ArrayList

    原创文章,转载请标注出处:<Java基础系列-ArrayList> 一.概述 ArrayList底层使用的是数组.是List的可变数组实现,这里的可变是针对List而言,而不是底层数组. ...

  7. Java基础系列-Collector和Collectors

    原创作品,可以转载,但是请标注出处地址:https://www.cnblogs.com/V1haoge/p/10748925.html 一.概述 Collector是专门用来作为Stream的coll ...

  8. Java基础系列-equals方法和hashCode方法

    原创文章,转载请标注出处:<Java基础系列-equals方法和hashCode方法> 概述         equals方法和hashCode方法都是有Object类定义的. publi ...

  9. Java基础系列-Comparable和Comparator

    原创文章,转载请标注出处:<Java基础系列-Comparable和Comparator> 一.概述         Java中的排序是由Comparable和Comparator这两个接 ...

随机推荐

  1. python3 生成器初识 NLP第五条

    话不多说,先把第五条抄一遍: 五,沟通的意义在于对方的回应 沟通没有对与错,只有“有效果”或者“没有效果”之分. 自己说得多“对”没有意义,对方收到你想表达的讯息才是沟通的意义. 因此自己说什么不重要 ...

  2. NumPy的基本用法

    NumPy简介:NumPy是高性能科学计算和数据分析的基础包.是pandas等其他各种工具的基础NumPy主要功能:ndarray,一个多维数组结构,高效且节省空间无需循环对数组数据进行快速运算的数学 ...

  3. 深入理解 new 操作符

    和其他高级语言一样 JavaScript 也有 new 操作符,我们知道 new 可以用来实例化一个类,从而在内存中分配一个实例对象. 但在 JavaScript 中,万物皆对象,为什么还要通过 ne ...

  4. 开源:Taurus.MVC 框架 (已支持.NET Core)

    为什么要创造Taurus.MVC: 记得被上一家公司忽悠去负责公司电商平台的时候,情况是这样的: 项目原版是外包给第三方的,使用:WebForm+NHibernate,代码不堪入目,Bug无限,经常点 ...

  5. ubuntu 16.04安装perf

    ljc@ubuntu:~$ perf 程序“perf”尚未安装. 您可以使用以下命令安装: sudo apt install linux-tools-common ljc@ubuntu:~$ sudo ...

  6. javascript 实现数据结构 - 栈

    栈是一种遵从后进先出(LIFO)原则的有序集合.新添加的或待删除的元素都保存在栈的同一端,称作栈顶,另一端就叫栈底.在栈里,新元素都靠近栈顶,旧元素都接近栈底.栈就好像是一个底部密封的盒子,我们往里面 ...

  7. 文本离散表示(二):新闻语料的one-hot编码

    上一篇博客介绍了文本离散表示的one-hot.TF-IDF和n-gram方法,在这篇文章里,我做了一个对新闻文本进行one-hot编码的小实践. 文本的one-hot相对而言比较简单,我用了两种方法, ...

  8. 在Windows上使用Docker运行.NetCore

    今天我们来说下如何在windows下使用docker运行.net core,既然是docker,那么我们首先得在windows上安装docker. 在Windows安装 docker 有两种选择 :1 ...

  9. Java集合详解4:HashMap和HashTable

    今天我们来探索一下HashMap和HashTable机制与比较器的源码. 具体代码在我的GitHub中可以找到 https://github.com/h2pl/MyTech 喜欢的话麻烦star一下哈 ...

  10. 数据结构系列(2)之 AVL 树

    本文将主要讲解平衡二叉树中的 AVL 树,其中将重点讲解二叉树的重平衡方法,即左旋和右旋,以及 3+4 重构:这些方法都是后面要讲的 B 树,红黑树等 BBST 的重要基础:此外在看本文之前最好先看一 ...