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. QuerySet的常用方法

    QuerySet常用方法 使用 connection.queries 可以查看sql语句 filter 将满足条件的结果返回,返回值为QuerySet对象 exclude 将满足条件的结果过滤掉,返回 ...

  2. Importing data in R 1

    目录 Importing data in R 学习笔记1 flat files:CSV txt文件 packages:readr read_csv() read_tsv read_delim() da ...

  3. bzoj 1483

    Description N个布丁摆成一行,进行M次操作.每次将某个颜色的布丁全部变成另一种颜色的,然后再询问当前一共有多少段颜色.例如颜色分别为1,2,2,1的四个布丁一共有3段颜色. Input 第 ...

  4. CrystalDecisions.Windows.Forms文件

    1.CrystalDecisions.Windows.Forms 相关dll文件 CrystalDecisions.Crystalreports.Engine.dllCrystalDecisions. ...

  5. [P3806] 【模板】点分治 - 点分治

    辣鸡蒟蒻怎么今天才来敲这个模板题 好像还敲了很久的样子 (大雾) #include <bits/stdc++.h> using namespace std; #define int lon ...

  6. Django教程(2)

    from Django official document; Django 最初被设计用于具有快速开发需求的新闻类站点,目的是要实现简单快捷的网站开发. from 编写你的第一个 Django 应用, ...

  7. SpringBoot+springDataJpa实现单表字段动态部分更新

    写在前面 所谓的动态部分更新是指:并非对数据记录的所有字段整体更新,而是知道运行时才确定哪个或者哪些字段需要被更新. 1)Spring Data Jpa对于Entity的更新,是对数据表中Entity ...

  8. Python入门3 —— 基本数据类型

    一:为何变量值(记录的数据)要有类型呢? 1.既然可以记录事物的状态,为什么要分类型呢? 变量值是来记录事物状态的, 而事物的状态是多种多样的, 所以对应着就要应该用不同类型的值去记录这些状态. 二: ...

  9. c++中sort函数调用报错Expression : invalid operator <的内部原理 及解决办法

    转自:https://www.cnblogs.com/huoyao/p/4248925.html 当我们调用sort函数进行排序时,中的比较函数如果写成如下 bool cmp(const int &a ...

  10. hadoop学习笔记(十):hdfs在命令行的基本操作命令(包括文件的上传和下载和hdfs中的文件的查看等)

    hdfs命令行 ()查看帮助 hdfs dfs -help ()查看当前目录信息 hdfs dfs -ls / ()上传文件 hdfs dfs -put /本地路径 /hdfs路径 ()剪切文件 hd ...