集合(Collection)

集合就是Java中提供的一种 空器,可以用来存储多个数据。

集合和数组都是一个容器,它们有什么区别呢?

  • 数组的长度是固定的,集合的长度是可变的。
  • 数组中存储的是同一类型的数据,并且也可以存储基本类型数据,但是集合中存储的都是对象,并且没有泛型的时候,还可以存储不同的对象。

Collection集合框架

Collection是一个集合类的顶级接口,所有的集合类的接口都是他的子类,或者实现类。

List接口:

1、在序的集合

2、允许存储生活重复的元素

3、有索引,可以使用普通的for循环遍历

set接口:

1、不允许有重复的元素

2、没有索引,不能进行普通的for循环

3、LinkedHashSet是有序的集合

Collection里面的方法

为什么要学习Collection里面的方法,是因为在用所有的Collection的实现类的时候,都可以用这些方法,所以学习这些方法就相当于学习了所有子类的方法,在以后学习子类方法的时候,只用学习一部分子类特有的就行了。

public boolean add(E e); 把给定的对象添加到当前集合中

public void clear(E e);清空集合中所有的元素

public boolean remove(E e);把给定的对象在当前集合中删除

public boolean contains(E e);判断当前集合中是否包含给定对象

public boolean isEmpty();判断当前集合是否为空

public int size();返回集合中元素的个数

public Object[] toArray();把集合中的元素,存储到数组中

使用:

创建一个集合:

public boolean add(E e);` 把给定的对象添加到当前集合中

    //使用多态
Collection<String> coll = new ArrayList<>();
coll.add("a");
coll.add("b");
coll.add("c");
coll.add("d");
//输出
System.out.println(coll);   //[a, b, c, d]

public void clear(E e);清空集合中所有的元素

    coll.clear();
System.out.println(coll);   //[]

public boolean remove(E e);把给定的对象在当前集合中删除

    coll.remove("a");
System.out.println(coll);   //[b, c, d]

public boolean contains(E e);判断当前集合中是否包含给定对象

    //包含返回true,没有返回false
System.out.println(coll.contains("c")); //true

public boolean isEmpty();判断当前集合是否为空

    //判断当前集合是否为空,如果为空则为true,否则为false
System.out.println(coll.isEmpty());     //false

public int size();返回集合中元素的个数

    System.out.println(coll.size());    //4

public T[] toArray(T[] a);把集合中的元素,存储到数组中

    //创建一个数组,这个数组的长度就是集合的长度
String[] strArr = new String[coll.size()];
//然后把集合中的元素全都存到数组中
coll.toArray(strArr);
for (String s : strArr) {
System.out.println(s);
/* 循环输出:
a
b
c
d
*/
}

迭代器(Iterator)

我们在开发中经常需要遍厉集合,所以JDK专门提供了一个接口java.util.Iterator,这个接口的作用主要是用来迭代访问Collection中的元素的,所以换为迭代器。

迭代器(Iterator)的原理和使用

因为Collection继承了Iterator,所以可以使用Collection里面的iterator(),来获取迭代器。

最初的迭器的使用:

    //使用多态
Collection<String> coll = new ArrayList<>();
coll.add("a");
coll.add("b");
coll.add("c");
coll.add("d");
System.out.println(coll); //[a, b, c, d]
//通过集合获取迭代器
Iterator<String> iterator = coll.iterator();
//用hasNext()方法来判断有没有下一个元素,如果有返回true
while (iterator.hasNext()) {
//用next()来获取下一个元素
//并且下标也移动到了当前元素下面,以方便上面的判断
String s = iterator.next();
System.out.println(s);
/* 迭代的结果:
a
b
c
d
*/
}

使用增强for循环:foreach来遍历集合,其实foreach里面也是使用Iterator来实现的。

    for (String s : coll) {
System.out.println(s);
/* 循环的结果:
a
b
c
d
*/
}

使用Java8里面的新特性Lambda表达式循环集合,其实这个里面封装的是增强for循环。

    coll.forEach(x -> System.out.println(x));
/* 循环的结果:
a
b
c
d
*/

forEach里面的方法:

    default void forEach(Consumer<? super T> action) {
Objects.requireNonNull(action);
for (T t : this) {
action.accept(t);
}
}

这个方法是在Iterator里面,是一个默认方法,因为Collection继承了这个方法,所以可以使用这个方法。

集合工具(Collections)

java.utils.Collections集合工具类,就是用来简化对集合进行操作的。

常用的方法

  • pubic stativc <T> boolean addAll(Collection<T> c,T... elements);往集合中批量添加元素。
  • public static void shuffle(List<?> list); 乱序。
  • public static <T> void sort(List<T> list); 将集合中的元素按昭默认规则排序。
  • public static <T> void sort(List<T> list, Comparator<? super T>);将集合中的元素按照指定规则进行排序。

使用

pubic stativc <T> boolean addAll(Collection<T> c,T... elements);往集合中批量添加元素。

    List<String> list = new ArrayList<>();
Collections.addAll(list, "a", "b", "c", "d");
System.out.println(list); //[a, b, c, d]

public static void shuffle(List<?> list); 乱序。

    List<String> list = new ArrayList<>();
Collections.addAll(list, "a", "b", "c", "d");
System.out.println(list); //[a, b, c, d]
Collections.shuffle(list);
System.out.println(list); //[d, b, a, c]随机的

public static <T> void sort(List<T> list); 将集合中的元素按昭默认规则排序。

    List<String> list = new ArrayList<>();
//无序的
Collections.addAll(list, "b", "d", "g", "o");
Collections.sort(list);
System.out.println(list); //[b, d, g, o]

public static <T> void sort(List<T> list, Comparator<? super T>);将集合中的元素按照指定规则进行排序。

    List<Integer> list = new ArrayList<>();
list.add(9);
list.add(3);
list.add(4);
list.add(2);
Collections.sort(list, new Comparator<Integer>() {
@Override
public int compare(Integer o1, Integer o2) {
//return o2 - o1; //[9, 4, 3, 2] 降序
return o1 - o2; //[2, 3, 4, 9] 升序
}
});
System.out.println(list);

细节决定成败!

个人愚见,如有不对,恳请扶正!

Java | 集合(Collection)和迭代器(Iterator)的更多相关文章

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

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

  2. Java 集合系列18之 Iterator和Enumeration比较

    概要 这一章,我们对Iterator和Enumeration进行比较学习.内容包括:第1部分 Iterator和Enumeration区别第2部分 Iterator和Enumeration实例 转载请 ...

  3. Java 集合-Collection接口和迭代器的实现

    2017-10-30 00:30:48 Collection接口 Collection 层次结构 中的根接口.Collection 表示一组对象,这些对象也称为 collection 的元素.一些 c ...

  4. java 集合2(迭代器)

    迭代器方法:(把迭代器想象成抓娃娃机的爪子) hasNext()     问是否有元素可遍历,如果有元素可以遍历,返回true,否则返回false 工作原理:这一个迭代的过程是这样的,获取到迭代器时候 ...

  5. java集合——Collection接口

    Collection是Set,List接口的父类接口,用于存储集合类型的数据. 2.方法 int size():返回集合的长度 void clear():清除集合里的所有元素,将集合长度变为0 Ite ...

  6. Thinking in Java——集合(Collection)

    一.ArrayList的使用(略) 二.容器的基本概念 (一).Collection是集合类的基本接口 主要方法: public interface Collection<E>{ bool ...

  7. java集合的操作(set,Iterator)

    集合的操作 Iterator.Collection.Set和HashSet关系 Iterator<——Collection<——Set<——HashSet Iterator中的方法: ...

  8. JAVA集合--Collection接口

        本文首发于cartoon的博客     转载请注明出处:https://cartoonyu.github.io/cartoon-blog     在概述里面也说过:Collection是jav ...

  9. Java 集合Collection与List的详解

    1.什么是集合 存储对象的容器,面向对象语言对事物的体现都是以对象的形式,所以为了方便对多个对象的操作,存储对象,集合是存储对象最常用的一种方式. 集合的出现就是为了持有对象.集合中可以存储任意类型的 ...

  10. Java集合--Collection

    概要 首先,我们对Collection进行说明.下面先看看Collection的一些框架类的关系图: Collection是一个接口,它主要的两个分支是:List 和 Set. List和Set都是接 ...

随机推荐

  1. Java,用户刷屏检测\相似字符串检测

    背景 近期有几个业务方提出一需求,期望判断一个用户在短期内是否存在刷屏现象,出现后能对其做出限制,并上报. 刷屏定义:取出用户近期20条评论,如果有50%的评论是"相似"的,则认为 ...

  2. 使用OneFlow搭建神经网络

    使用OneFlow搭建神经网络 在 识别 MNIST 手写体数字 的例子中,通过 flow.layers 和 flow.nn 中提供的接口搭建了一个简单的 LeNet 网络.下面,将通过LeNet来介 ...

  3. TensorFlow解析常量、变量和占位符

    TensorFlow解析常量.变量和占位符 最基本的 TensorFlow 提供了一个库来定义和执行对张量的各种数学运算.张量,可理解为一个 n 维矩阵,所有类型的数据,包括标量.矢量和矩阵等都是特殊 ...

  4. cuDNN概述

    cuDNN概述 NVIDIACUDA深度神经网络库(cuDNN)是GPU加速的用于深度神经网络的原语库.cuDNN为标准例程提供了高度优化的实现,例如向前和向后卷积,池化,规范化和激活层. 全球的深度 ...

  5. NVIDIA GPU卷积网络的自动调谐

    NVIDIA GPU卷积网络的自动调谐 针对特定设备和工作负载的自动调整对于获得最佳性能至关重要.这是关于如何为NVIDIA GPU调整整个卷积网络. NVIDIA GPU在TVM中的操作实现是以模板 ...

  6. 基于TensorRT的BERT实时自然语言理解(上)

    基于TensorRT的BERT实时自然语言理解(上) 大规模语言模型(LSLMs)如BERT.GPT-2和XL-Net为许多自然语言理解(NLU)任务带来了最先进的精准飞跃.自2018年10月发布以来 ...

  7. JAVA并发(6)-并发队列ArrayBlockingQueue

    本文讲ArrayBlockingQueue 1. 介绍 一个基于数组的有界阻塞队列,FIFO顺序.支持等待消费者和生产者线程的可选公平策略(默认是非公平的).公平的话通常会降低吞吐量,但是可以减少可变 ...

  8. Flink实时计算pv、uv的几种方法

    本文首发于:Java大数据与数据仓库,Flink实时计算pv.uv的几种方法 实时统计pv.uv是再常见不过的大数据统计需求了,前面出过一篇SparkStreaming实时统计pv,uv的案例,这里用 ...

  9. PyQt5开发实践(一、准备篇)

    前言 近一年来我开发了不少PyQt小项目,因为之前没用过使用C++语言的Qt,所以可以算是从零基础开始边学边做的,这个过程中再一次体会到国内技术社区的匮乏-- 国内关于PyQt的资料说少不少,说多也不 ...

  10. 性能工具之stress工具使用教程(带源码说明)

      stress是一个在linux下的压力测试小工具. 我看到有些人用这个工具来描述一些资源耗尽的场景,也有人用它来做混沌测试中.请使用者要注意,这个工具并不是模拟业务问题的,是模拟系统级问题的.所以 ...