Collection体系(集合类,它是一个接口):
    两个子类:
        List、Set(这两个子类也是接口)
            List有两个常用子类:(值,不唯一,允许有重复的元素,都是有序的)
                ArrayList:
                    数组结构,查找快,增删慢。线程不安全。
                LinkedList:
                    有序,链表结构,查找慢,增删快。线程不安全。
                Vector:(以过时)
                    有序,数组结构,查找增删都慢。线程安全。
            Set:有三个常用子类(值,唯一,不允许有重复的元素)
                HashSet:
                    底层是哈希表结构,无序。
                    如何保证唯一性的?
                        由HashCode和equals方法保证唯一性的。
                    顺序:
                        先判断HashCode方法
                            相同:判断equals方法,相同:不添加。不相同:添加
                            不相同:添加
                LinkedHashSet:
                    有序,底层是链表加哈希表结构,由链表保证有序,哈希表保证唯一。
                TreeSet:
                    底层是二叉树结构,有一定的自然排序算法。
                    是如何保证元素的唯一性的?
                        根据返回值是否是0判断是否重复。并且还要保证元素有序:
                            根据返回值是正数还是负数。
                            实现方案:添加比较器
                                元素具备比较器:实现Comparable接口,重写CompareTo方法。
                                集合具备比较器:实现Comparator接口,重写Compare方法。
 
                                
 
List和Set集合遍历的几种方式:
    Set集合是没有普通for的遍历方式
    普通for、增强for、迭代器
        普通for格式:
            for(int i = 0; i < list.size(); i++){}
        增强for格式:
            for(类型 变量名 : 集合名){}
        迭代器格式:(提供了两个方法:hasNext和next方法)
            Iterator<类型> it = 集合名.iterator();
    什么时候使用?
        需要操作集合的角标的时候使用普通for
        只需要遍历集合的时候使用增强for或迭代器。
        
        
泛型:
    泛型的通配符为:?
    <? extends T> 向下限制,只可以传递T类型或T类型的子类
    <? super T> 向上限制,只可以传递T类型或T类型的父类
泛型的定义:定义泛型可以在类中预支地使用未知的类型。可定义在类、方法或接口上。
泛型的使用:一般在创建对象时,将未知的类型确定具体的类型。当没有指定泛型时,默认类型为Object类型。
泛型的好处:
    将运行时期的ClassCastException,转移到了编译时期变成了编译失败。
    避免了类型强转的麻烦。
泛型的格式:
    类上:
    修饰符 class 类名<代表泛型的变量> {  }
        使用格式:
            使用格式:创建对象时,确定泛型的类型
    接口上:
    interface 类名<代表泛型的变量>{ }
        使用格式:
            1、定义类时确定泛型的类型
            2、始终不确定泛型的类型,直到创建对象时,确定泛型的类型
 
    方法上:
    修饰符<> 返回值类型 方法名(泛型变量  变量名){}
        使用格式:
            使用格式:调用方法时,确定泛型的类型

Collection体系、遍历、泛型的更多相关文章

  1. 一点一点看JDK源码(一)Collection体系概览

    一点一点看JDK源码(一)Collection体系概览 liuyuhang原创,未经允许进制转载 本文举例使用的是JDK8的API 目录:一点一点看JDK源码(〇) 1.综述 Collection为集 ...

  2. java遍历泛型的方法

    一.List遍历 Java中List遍历有三种方法来遍历泛型,主要为: 1.for循环遍历 2.iterator遍历 3.foreach遍历 package com.gmail.lsgjzhuwei; ...

  3. C# 遍历泛型集合

    /// <summary> /// 遍历泛型 /// </summary> /// <typeparam name="T"></typep ...

  4. Collection类,泛型

    Collection(接口) 所有超级接口: Iterable<E> 一.集合 1.集合的介绍&集合和数组的区别 什么是集合:java中的一种容器 什么是数组:java中的一种容器 ...

  5. 循环遍历泛型集合List绑定到table

    <%@ Page Language="C#" AutoEventWireup="true" EnableViewState="false&quo ...

  6. Collection体系

  7. Java集合:Collection、List、Set、Map、泛型

    1.集合的理解和好处 2.集合的框架体系图 ★ 3.Collection接口的特点和使用 ★ 4.List和Set接口的特点和使用★ 5.List接口的实现类学习★ 6.Set接口的实现类学习★ 7. ...

  8. Java集合 Collection、Set、Map、泛型 简要笔记

    集合 什么是集合 概念 对象的容器,实现了对对象常用的操作 和数组的区别 数组长度固定,集合长度不固定 数组可以存储基本类型和引用类型,集合只能存储引用类型 位置 java.util.*; Colle ...

  9. 大数据之路week02 Collection 集合体系收尾(Set)

    1.Set集合(理解) (1)Set集合的特点 无序,唯一. (2)HashSet集合(掌握) A: 底层数据结构是哈希表(是一个元素为链表的数组) B: 哈希表底层依赖两个方法: hashCode( ...

随机推荐

  1. 白面系列 mongoDB

    mongoDB和redis一样,都是noSQL技术之一. redis是Key-Value存储,mongoDB是文档存储. 文档存储一般用类似json的格式存储,存储的内容是文档型的.文档是一组键值(k ...

  2. Mac 安装IDEA 2018.3 版本

    注:本文转自https://blog.csdn.net/qq_41735004/article/details/86670039 写文文的目的是,怕博主删掉然后找不到所以就写一份 1.下载idea和破 ...

  3. Eclipse项目转到MyEclipse中出错

    原因如下. JDK的编译版本和JRE的运行版本不一致导致了这个问题. 在MyEclipse中,对项目进行Build path 逐一设置即可. 还有关于类型转换的问题,由于JDK版本的不一致,下载下来的 ...

  4. R data formats

    R data formats: Rdata Rda Rds 1.概念 rds是R语言中利用二进制保存的源文件,加载readr包以后,使用write_rds(x,file='x.rds')保存文件,re ...

  5. 并查集路径压缩优化 UnionFind PathCompression(C++)

    /* * UnionFind.h * 有两种实现方式,QuickFind和QuickUnion * QuickFind: * 查找O(1) * 合并O(n) * QuickUnion:(建议使用) * ...

  6. Codeforces Round #623 (Div. 1, based on VK Cup 2019-2020 - Elimination Round, Engine)A(模拟,并查集)

    #define HAVE_STRUCT_TIMESPEC #include<bits/stdc++.h> using namespace std; pair<]; bool cmp( ...

  7. Tensorflow机器学习入门——cifar10数据集的读取、展示与保存

    基本信息 官网:http://www.cs.toronto.edu/~kriz/cifar.html 共60000张图片:50000张用于训练.10000张用于测试 图片大小为:32X32 数据集图片 ...

  8. OpenCV的视频读取

    现在找一个能拍摄视频的设备真是太容易了.结果大家都用视频来代替以前的序列图像.视频可能由两种形式得到,一个是像网络摄像头那样实时视频流,或者由其他设备产生的压缩编码后的视频文件.幸运的是,OpenCV ...

  9. 快速排序 QuickSort (C++迭代,递归)

    /* * QuickSort.h * 快速排序(将每一个元素转换为轴点元素) * Created on: 2020年2月12日 * Author: LuYonglei */ #ifndef SRC_Q ...

  10. 编写自定义的django-admin命令

    先写标题内容后续补充上 官方文档如下 :http://python.usyiyi.cn/documents/django_182/howto/custom-management-commands.ht ...