集合是类,用来存储多个数据,有属性、方法

集合是一个可变数组,保存相同元素并且长度可变

1. 体系

(1)Collection:存储一个一个的值

Iterable:

Iterable<T> iterator()

返回一个组T类型的元素上进行迭代的迭代器

用来遍历元素的对象

Collection子接口:List、Set

List

特点:元素可重复,有序(有序号的),完全可以使用List替换数组

有序:放进去的顺序和拿出来的顺序是一样的

Set

特点:元素不可重复,无序(无序号的)

无序:放进去的顺序和拿出来的顺序不一样

Queue:队列(会和线程公用,暂时不掌握)

(2)Map:存储一对一对的值,键值对(key-value)

泛型

只能是引用类型

可以把数据类型变量化

可以根据需要指定类型

a.可以在类上加泛型,整个类都可以用,在创建对象时指定类型

可以限定泛型的类型:

T extends 父类:向下限定

T super:向下限定

b.对于静态方法,可以在方法上加泛型

访问修饰符<泛型列表> 返回值类型 方法名(参数列表){

实现代码

}

2. ArrayList

使用语法:ArrayList<引用数据类型> arrayList=new ArrayList<>();

常用方法:

3. 遍历集合(List的遍历)

方法一:for循环

for(int i=0;i<array.size();i++){

  system.out.printlt(array.get(i));

}

方法二:迭代器(必须掌握)

遍历数组尽量使用迭代器,因为靠谱

 

(1)迭代器相关方法API:

void

forEachRemaining(Consumer<? super E> action)

对每个剩余元素执行给定的操作,直到所有元素都被处理或动作引发异常。

boolean

hasNext()

如果迭代具有更多元素,则返回 true 。

E

next()

返回迭代中的下一个元素。

void

remove()

从底层集合中删除此迭代器返回的最后一个元素(可选操作)。

(2)迭代器删除方法使用案例

方法三:foreach(增强for循环)

语法:for(元素类型 变量名:Collection集合){

system.out.printl(变量名);

}

 

Collection,数组都可以

实现Iterable接口的类可以成为foreach的目标

适用于做遍历输出

本质上:还是使用迭代器

4. ArrayList的排序

方法一:冒泡排序

方法二:Comparable比较接口

接口 Comparable<T>

参数类型:

T - 可以将此对象与之进行比较的对象类型

方法:

int compareTo(T o) :比较此对象与指定对象的顺序

o -  要比较的对象

返回:

负整数、零或正整数,根据此对象是小于、大于、等于指定对象

当前对象大于传入对象,返回正整数

当前对象等于传入对象,返回零

当前对象小于传入对象,返回负整数

一个类实现是这个接口,意味着可以通过int compareTo进行比较大小

借助Collections:工具类

short()方法:排序

总结:

1) 元素类实现Comparable接口,重写CompareTo方法

2) 利用Collection.short(List)排序

方法三:单独一个类实现Comparator接口,具备比较两个元素大小的方法

Comparator<T>:

int compare(T o1,T o2)   比较用来排序的两个参数

参数:o1---要比较的第一个对象

o2---要比较的第二个对象

返回:

根据第一个参数小于、等于、大于第二个参数分别返回负整数、零、正整数

1)定义类,实现Comparator的继承,重写Compare方法

2)实现排序

或者使用匿名内部类直接实现排序:

Java学习笔记之——集合的更多相关文章

  1. Java学习笔记之---集合

    Java学习笔记之---集合 (一)集合框架的体系结构 (二)List(列表) (1)特性 1.List中的元素是有序并且可以重复的,成为序列 2.List可以精确的控制每个元素的插入位置,并且可以删 ...

  2. Java学习笔记之集合

    集合(Collection)(掌握) (1)集合的由来? 我们学习的是Java -- 面向对象 -- 操作很多对象 -- 存储 -- 容器(数组和StringBuffer) -- 数组而数组的长度固定 ...

  3. 【原】Java学习笔记026 - 集合

    package cn.temptation; public class Sample01 { public static void main(String[] args) { // 需求:从三国演义中 ...

  4. java学习笔记之集合家族2

    集合体系 一.数据结构 List集合储存数据结构 <1>堆栈结构 特点:先进后出 <2>队列结构 特点:先进先出 <3>数组结构 特点:查询快,增删慢 <4& ...

  5. 【Java学习笔记】集合转数组---toArray()

    package p2; import java.util.ArrayList; import java.util.Arrays; import java.util.List; public class ...

  6. 【Java学习笔记】<集合框架>定义功能去除ArrayList中的重复元素

    import java.util.ArrayList; import java.util.Iterator; import cn.itcast.p1.bean.Person; public class ...

  7. java学习笔记之集合家族1

    集合 集合介绍: 由于数组中存放对象,对对象操作起来不方便.java中有一类容器,专门用来存储对象. 集合与数组的区别: 1.数组的长度固定的,而集合长度时可变的 2.数组只能储存同一类型的元素,而且 ...

  8. 【原】Java学习笔记028 - 集合

    package cn.temptation; import java.util.HashSet; import java.util.Set; public class Sample01 { publi ...

  9. 5.3类集(java学习笔记)集合的输出

    一.集合的输出 迭代输出:Iteratror接口 在输出集合时,最标准的方法是使用迭代器迭代输出. 1,List中的迭代器. Iterator中包含三个方法: hasNex()t判断集合内是否有元素存 ...

  10. java学习笔记——Collection集合接口

    NO 方法名称 描述 1 public boolean add(E e) 向集合中保存数据 2 public void clear() 清空集合 3 public boolean contains(O ...

随机推荐

  1. 干货分享: 长达250页的Libvirt Qemu KVM的ppt,不实验无真相

    下载地址:Libvirt Qemu KVM 教程大全 http://files.cnblogs.com/popsuper1982/LibvirtQemuKVM.pptx 1. 概论 1.1 虚拟化的基 ...

  2. Hadoop 集群安装(从节点安装配置)

    1.Java环境配置 view plain copy sudo mv /tmp/java /opt/ jdk安装完配置环境变量,编辑/etc/profile: view plain copy sudo ...

  3. vue项目实践-添加axios封装api请求

    安装 axios npm install axios --save 创建实例 (utils/fetch.js) axios 默认提交格式为:application/json 可使用 qs 模块(需要安 ...

  4. 高级Java面试总结3

    1,java堆,分新生代老年代,新生代有Eden,from surviver,to surviver三个空间,堆被所有线程共.eden内存不足时,发生一次minor GC,会把from survivo ...

  5. [Swift]LeetCode561. 数组拆分 I | Array Partition I

    Given an array of 2n integers, your task is to group these integers into n pairs of integer, say (a1 ...

  6. [Swift]LeetCode941. 有效的山脉数组 | Valid Mountain Array

    Given an array A of integers, return true if and only if it is a valid mountain array. Recall that A ...

  7. 一个简单IP防刷工具类, x秒内最多允许y次单ip操作

    IP防刷,也就是在短时间内有大量相同ip的请求,可能是恶意的,也可能是超出业务范围的.总之,我们需要杜绝短时间内大量请求的问题,怎么处理? 其实这个问题,真的是太常见和太简单了,但是真正来做的时候,可 ...

  8. C#基础语法

    究极入门之Hello world static void Main(string[] args) { //你好,世界 Console.WriteLine("HELLO WORLD" ...

  9. 「造个轮子」——cicada(轻量级 WEB 框架)

    前言 俗话说 「不要重复造轮子」,关于是否有必要不再本次讨论范围. 创建这个项目的主要目的还是提升自己,看看和知名类开源项目的差距以及学习优秀的开源方式. 好了,现在着重来谈谈 cicada 这个项目 ...

  10. 动手实现一个 LRU cache

    前言 LRU 是 Least Recently Used 的简写,字面意思则是最近最少使用. 通常用于缓存的淘汰策略实现,由于缓存的内存非常宝贵,所以需要根据某种规则来剔除数据保证内存不被撑满. 如常 ...