Java-单列集合Collection详解

2024-04-21 19:20

本文主要是介绍Java-单列集合Collection详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、单列集合

单列集合一次只能添加一个元素

Collection是顶层父类接口

List系列集合:

添加的元素是有序、可重复、有索引的,其中有序指的是存和取得顺序一致(e.g:我存进去的是1,2,3,取出来的是1,2,3),重复指的是集合中存储的元素是可以重复的,有索引指的是我们可以通过索引获取每一个元素。

Set系列集合:

添加的元素是无序、不重复、无索引的,其中无序指的是存和取得顺序可能不一致(e.g:我存进去的是1,2,3,取出来的可能是3,1,2),不重复指的是集合中存储的元素是不可以重复的,无索引指的是我们不可以通过索引获取每一个元素。

二、单列集合之Collection的概念

Collection是单列集合的祖宗接口(顶层父接口),它的功能是全部单列集合都可以使用的。

三、单列集合之Collection创建集合

Collection是接口 不能直接创建集合对象,但是可以通过该接口的具体类来创建集合对象,在Java中,一个对象变量可以引用任何实现了特定接口的类的实例(比如下面例子中的coll),这是java中多态的作用,你可以通过接口来引用任何实现了该接口的类的实例,从而增加了代码的灵活性和可维护性。因为你可以轻松地改变 coll 背后使用的实现类,而不需要修改所有使用 coll 的代码。例如,你可以将 new ArrayList<>() 替换为 new LinkedList<>() 或其他任何实现了 Collection 接口的类的实例,而无需修改其他代码。

e.g:  Collection<Integer> coll=new ArrayList<>();

通过ArrayList实现类创建集合

四、单列集合之Collection的常用方法

注意:Collection是接口,在使用它的方法时,不能创建它的对象,要创建它的实现类,通过它的实现类来使用接口的方法

1、添加元素

语法:集合名称.add(元素);

当往List系列添加元素时,返回值永远是true,因为List可以添加重复元素

当往Set系列添加元素时,当该元素已经在集合中存在时,那么返回值是false,当该元素集合中没有存在时,那么返回值是true,因为Set不可以添加重复元素

import java.util.ArrayList;
import java.util.Collection;public class test1 {public static void main(String[] args) {// 生成一个coll变量 它的类型是Collection 表示一组元素 其元素类型必须是StringCollection<String> coll=new ArrayList<>();// 1.添加// 返回值为布尔类型boolean r1= coll.add("abc");System.out.println(r1);// trueSystem.out.println(coll);// [abc]boolean r2= coll.add("efg");System.out.println(r2);// trueSystem.out.println(coll);// [abc, efg]}
}

2、清空集合

语法:集合名称.clear();

当往List系列添加元素时,返回值永远是true,因为List可以添加重复元素

当往Set系列添加元素时,当该元素已经在集合中存在时,那么返回值是false,当该元素集合中没有存在时,那么返回值是true,因为Set不可以添加重复元素

import java.util.ArrayList;
import java.util.Collection;public class test1 {public static void main(String[] args) {// 生成一个coll变量 它的类型是Collection 表示一组元素 其元素类型必须是StringCollection<String> coll=new ArrayList<>();// 1.添加// 返回值为布尔类型boolean r1= coll.add("abc");System.out.println(r1);// trueSystem.out.println(coll);// [abc]boolean r2= coll.add("efg");System.out.println(r2);// trueSystem.out.println(coll);// [abc, efg]//2.清空//清空集合所有的元素coll.clear();System.out.println(coll);// []}
}

3、删除元素

语法:集合名称.remove(元素);

当要删除的元素在集合中存在时,那么返回值是true,当该元素集合中没有存在时,那么返回值是false

Collection 接口没有提供按索引删除元素的方法。Collection 接口定义的方法都是基于元素的,而不是基于索引的。

import java.util.ArrayList;
import java.util.Collection;public class test1 {public static void main(String[] args) {// 生成一个coll变量 它的类型是Collection 表示一组元素 其元素类型必须是StringCollection<String> coll=new ArrayList<>();// 1.添加// 返回值为布尔类型boolean r1= coll.add("abc");System.out.println(r1);// trueSystem.out.println(coll);// [abc]boolean r2= coll.add("efg");System.out.println(r2);// trueSystem.out.println(coll);// [abc, efg]// 2.删除// 删除成功返回true 删除失败返沪falseboolean r3=coll.remove("abc");System.out.println(r3);// trueSystem.out.println(coll);// [efg]boolean r4=coll.remove("aaa");System.out.println(r4);// falseSystem.out.println(coll);// [efg]}
}

4、判断集合是否包含该元素

语法:集合名称.contains(元素);

当要元素在集合中存在时,那么返回值是true,当该元素集合中没有存在时,那么返回值是false

细节:它的底层逻辑是通过equals方法进判断的,因此当集合存储的元素是对象时,也想通过

contains判断该对象是否存在时,需要重写JavaBean的contains方法

import java.util.ArrayList;
import java.util.Collection;public class test1 {public static void main(String[] args) {// 生成一个coll变量 它的类型是Collection 表示一组元素 其元素类型必须是StringCollection<String> coll=new ArrayList<>();// 1.添加// 返回值为布尔类型boolean r1= coll.add("abc");System.out.println(r1);// trueSystem.out.println(coll);// [abc]boolean r2= coll.add("efg");System.out.println(r2);// trueSystem.out.println(coll);// [abc, efg]// 2.判断元素是否包含boolean r3=coll.contains("aaa");System.out.println(r3);// falseboolean r4=coll.contains("abc");System.out.println(r4);// true}
}

5、判断集合是否为空

语法:集合名称.isEmpty();

import java.util.ArrayList;
import java.util.Collection;public class test1 {public static void main(String[] args) {// 生成一个coll变量 它的类型是Collection 表示一组元素 其元素类型必须是StringCollection<String> coll=new ArrayList<>();// 1.添加// 返回值为布尔类型boolean r1= coll.add("abc");System.out.println(r1);// trueSystem.out.println(coll);// [abc]boolean r2= coll.add("efg");System.out.println(r2);// trueSystem.out.println(coll);// [abc, efg]// 2.判断元素是否为空boolean r3=coll.isEmpty();System.out.println(r3);// false}
}

6、获取集合的长度

语法:集合名称.size();

public class test1 {public static void main(String[] args) {// 生成一个coll变量 它的类型是Collection 表示一组元素 其元素类型必须是StringCollection<String> coll=new ArrayList<>();// 1.添加// 返回值为布尔类型boolean r1= coll.add("abc");System.out.println(r1);// trueSystem.out.println(coll);// [abc]boolean r2= coll.add("efg");System.out.println(r2);// trueSystem.out.println(coll);// [abc, efg]// 2.判断元素是否为空int r3=coll.size();System.out.println(r3);// 2}
}

五、单列集合之Collection的遍历方式

Collection的遍历方式有三种,迭代器遍历、增强for遍历、lamda表达式遍历,没有普通的for循环遍历,因为普通的for循环遍历需要通过索引遍历,而set没有索引,因此没有普通的for循环遍历

1、迭代器遍历

迭代器在java中的类是Iterator,迭代器是集合专用的遍历方式

step1:Collection获取迭代器的方式是Iterator<集合元素类型>迭代器名称=集合名称.Iterator();

  • Iterator 是Java集合框架中的一个接口,它提供了一种遍历集合元素的方式。
  • <String> 是一个泛型参数,它指定了这个迭代器将用于遍历包含String类型元素的集合。

它返回迭代器对象(指针),默认指向当前集合的0索引

step2:迭代器对象名称.hasnext();用来判断当前位置是否存在元素,如果存在则返回true,如果不存在则返回false

step3:迭代器对象名称.next();用来获取当前位置的元素,并将迭代器指向下一个位置

通过这三种方法 我们就可以遍历集合

语法:

Iterator<集合元素类型>迭代器名称=集合名称.Iterator();

while(迭代器对象名称.hasnext()){

        System.out.println(迭代器对象名称.next());

}

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;public class 迭代器遍历 {public static void main(String[] args) {// 1.创建集合并添加元素Collection<String> coll=new ArrayList<>();coll.add("文韬");coll.add("黄子弘凡");coll.add("何运晨");// 2.创建迭代器对象Iterator<String> it=coll.iterator();// 3.迭代器遍历集合while (it.hasNext()){System.out.println(it.next());}// 文韬// 黄子弘凡// 何运晨}
}

注意点:

①迭代器遍历完毕,指针不会复位

如果想要遍历第二次 就要生成新的迭代器对象

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;public class 迭代器遍历 {public static void main(String[] args) {// 1.创建集合并添加元素Collection<String> coll=new ArrayList<>();coll.add("文韬");coll.add("黄子弘凡");coll.add("何运晨");// 2.创建迭代器对象Iterator<String> it=coll.iterator();// 3.迭代器遍历集合while (it.hasNext()){System.out.println(it.next());}// 文韬// 黄子弘凡// 何运晨// 迭代器遍历完毕,指针不会复位// 以下结果都是false 因为遍历完集合 指针指向没有元素的位置 而且不会复原System.out.println(it.hasNext());// falseSystem.out.println(it.hasNext());// falseSystem.out.println(it.hasNext());// falseSystem.out.println(it.hasNext());// falseSystem.out.println(it.hasNext());// false// 遍历第二次// 需要生成新的迭代器对象Iterator<String> it2=coll.iterator();while (it2.hasNext()){System.out.println(it2.next());}// 文韬// 黄子弘凡// 何运晨}}
}

②循环中只能使用一次next方法

如果在循环中使用多次next方法就可能出现该位置没有元素的情况

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;public class 迭代器遍历 {public static void main(String[] args) {// 1.创建集合并添加元素Collection<String> coll=new ArrayList<>();coll.add("文韬");coll.add("黄子弘凡");coll.add("何运晨");// 2.创建迭代器对象Iterator<String> it=coll.iterator();// 3.迭代器遍历集合while (it.hasNext()){System.out.println(it.next());System.out.println(it.next());}// 文韬// 黄子弘凡// 何运晨// 报错:NoSuchElementException}
}

③迭代器遍历时,不能用集合的方式进行增加或删除,必须用迭代器的方法进行删除

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;public class 迭代器遍历 {public static void main(String[] args) {// 1.创建集合并添加元素Collection<String> coll=new ArrayList<>();coll.add("文韬");coll.add("黄子弘凡");coll.add("何运晨");// 2.创建迭代器对象Iterator<String> it=coll.iterator();// 3.迭代器遍历集合while (it.hasNext()){System.out.println(it.next());// 通过迭代器的remove方法删除元素it.remove();// 如果不输出当前元素的值 而是直接删除当前元素的值并将指针下移 就会报错}// 4.输出集合中的元素System.out.println(coll);}
}

④当迭代器遍历完之后再次使用 迭代器对象名称.next()就会报错

import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;public class 迭代器遍历 {public static void main(String[] args) {// 1.创建集合并添加元素Collection<String> coll=new ArrayList<>();coll.add("文韬");coll.add("黄子弘凡");coll.add("何运晨");// 2.创建迭代器对象Iterator<String> it=coll.iterator();// 3.迭代器遍历集合while (it.hasNext()){System.out.println(it.next());}// 文韬// 黄子弘凡// 何运晨// 当迭代器遍历完之后再次使用 迭代器对象名称.next()就会报错System.out.println(it.next());// NoSuchElementException 表示不存在这个元素}
}

迭代器总结:

1、迭代器遍历不需要依赖索引,它是通过创建指针并移动指针来遍历集合中的元素

2、迭代器需要掌握的三种方法

Iterator<集合元素类型>迭代器名称=集合名称.Iterator();

迭代器对象名称.hasnext();

迭代器对象名称.next();

2、增强for遍历

增强for的底层就是迭代器,是为了简化迭代器的代码书写的

所有的单列集合和数组才能用增强for进行遍历

语法:

for(元素的数据类型 变量名:数组或者单列集合){

}

其中变量名存储的内容就是遍历过程中的每一个元素

import java.util.ArrayList;
import java.util.Collection;public class 增强for遍历 {public static void main(String[] args) {// 1.创建集合并添加元素Collection<String> coll=new ArrayList<>();coll.add("文韬");coll.add("黄子弘凡");coll.add("何运晨");// 2.增强for循环遍历// String表示遍历元素的类型 s用来存储遍历的每一个元素 coll表示遍历的集合名称for(String s:coll){System.out.println(s);// 遍历过程中的每一个元素}// 文韬// 黄子弘凡// 何运晨}
}

注意:当修改变量名存放的内容时,并不会修改集合的内容

import java.util.ArrayList;
import java.util.Collection;public class 增强for遍历 {public static void main(String[] args) {// 1.创建集合并添加元素Collection<String> coll=new ArrayList<>();coll.add("文韬");coll.add("黄子弘凡");coll.add("何运晨");// 2.增强for循环遍历// String表示遍历元素的类型 s用来存储遍历的每一个元素 coll表示遍历的集合名称// 修改变量s的内容并不会改变集合的内容for (String s : coll) {s="aaa";}System.out.println(coll);// 文韬// 黄子弘凡// 何运晨// 输出结果不会变成:// aaa// aaa// aaa}
}

生成增强for语句的快捷方式:

遍历的集合名称.for并回车即可生成

for(元素的数据类型 变量名:数组或者单列集合){

}

3、lamdba表达式遍历

语法:

Collection<遍历元素的数据类型> 集合对象名称=new ArrayList<>();

集合对象名称.forEach(s->System.out.println(s));

step1:生成集合对象     e.g: Collection<Integer> coll=new ArrayList<>();

step2:通过集合对象使用forEach方法 ,方法中写变量加上->输出元素的语句

  e.g:coll.forEach(s-> System.out.println(s));

import java.util.ArrayList;
import java.util.Collection;
import java.util.function.Consumer;public class lamdba遍历 {public static void main(String[] args) {Collection<String> coll=new ArrayList<>();coll.add("文韬");coll.add("黄子弘凡");coll.add("曹恩齐");// forEach是Iterable接口的默认方法 用于遍历集合中的每个元素 并对每个元素执行一个给定的操作// Collection接口拓展了Iterable接口,因此所有实现Collection接口的类也实现了Iterable接口// 因此实现Collection接口的对象coll也可以使用Iterable接口的方法forEach// forEach需要传入Consumer接口 当方法的参数是接口时 在调用方法时需要传递接口的实现类// 生成Consumer实现类的对象// 由于Consumer接口只有一个抽象方法 其实现类是函数式接口的匿名内部类 可以使用lamdba表达式简化// 简化lamdba表达式// 1.简化前coll.forEach(new Consumer<String>(){@Overridepublic void accept(String s){System.out.println(s);}});/*文韬黄子弘凡曹恩齐*/// 2.简化后coll.forEach( s-> System.out.println(s));/* 文韬黄子弘凡曹恩齐*/}
}

六、补充知识:lambda表达式简化接口的匿名形式

函数式编程:忽略面向对象的复杂语法,强调做什么而不是谁去做,做什么强调的是重写方法的形参类型、方法体、return返回值

语法:

()->{

}

其中()对应着重写方法的形参   ->是固定格式   {}对应着方法的方法体

简化规则:

1、参数类型可以省略不写

简化前:

简化后:

2、当只有一个参数时,参数类型可以省略不写,同时()也可以省略不写

3、如果lamdba表达式的方法体只有一行,那么大括号、分号、return可以省略不写,要省略需同时省略,不能只省略大括号、分号、return中的一部分

简化前:

简化后:

注意:

1、lambda表达式可以用来简化匿名内部类的书写

2、lambda表达式只能简化函数式接口的匿名内部类,其中函数式接口指的是有且仅有一个抽象方法的接口(只能是接口不能是抽象类),接口上方可以加@FuctionInterface注解来检验

e.g1:

e.g2:

简化前:

简化后:

七、单列集合之Collection的知识总结

这篇关于Java-单列集合Collection详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/923851

相关文章

Redis中6种缓存更新策略详解

《Redis中6种缓存更新策略详解》Redis作为一款高性能的内存数据库,已经成为缓存层的首选解决方案,然而,使用缓存时最大的挑战在于保证缓存数据与底层数据源的一致性,本文将介绍Redis中6种缓存更... 目录引言策略一:Cache-Aside(旁路缓存)策略工作原理代码示例优缺点分析适用场景策略二:Re

SpringBoot中四种AOP实战应用场景及代码实现

《SpringBoot中四种AOP实战应用场景及代码实现》面向切面编程(AOP)是Spring框架的核心功能之一,它通过预编译和运行期动态代理实现程序功能的统一维护,在SpringBoot应用中,AO... 目录引言场景一:日志记录与性能监控业务需求实现方案使用示例扩展:MDC实现请求跟踪场景二:权限控制与

Java NoClassDefFoundError运行时错误分析解决

《JavaNoClassDefFoundError运行时错误分析解决》在Java开发中,NoClassDefFoundError是一种常见的运行时错误,它通常表明Java虚拟机在尝试加载一个类时未能... 目录前言一、问题分析二、报错原因三、解决思路检查类路径配置检查依赖库检查类文件调试类加载器问题四、常见

Java注解之超越Javadoc的元数据利器详解

《Java注解之超越Javadoc的元数据利器详解》本文将深入探讨Java注解的定义、类型、内置注解、自定义注解、保留策略、实际应用场景及最佳实践,无论是初学者还是资深开发者,都能通过本文了解如何利用... 目录什么是注解?注解的类型内置注编程解自定义注解注解的保留策略实际用例最佳实践总结在 Java 编程

MySQL数据库约束深入详解

《MySQL数据库约束深入详解》:本文主要介绍MySQL数据库约束,在MySQL数据库中,约束是用来限制进入表中的数据类型的一种技术,通过使用约束,可以确保数据的准确性、完整性和可靠性,需要的朋友... 目录一、数据库约束的概念二、约束类型三、NOT NULL 非空约束四、DEFAULT 默认值约束五、UN

Python使用Matplotlib绘制3D曲面图详解

《Python使用Matplotlib绘制3D曲面图详解》:本文主要介绍Python使用Matplotlib绘制3D曲面图,在Python中,使用Matplotlib库绘制3D曲面图可以通过mpl... 目录准备工作绘制简单的 3D 曲面图绘制 3D 曲面图添加线框和透明度控制图形视角Matplotlib

MySQL中的分组和多表连接详解

《MySQL中的分组和多表连接详解》:本文主要介绍MySQL中的分组和多表连接的相关操作,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录mysql中的分组和多表连接一、MySQL的分组(group javascriptby )二、多表连接(表连接会产生大量的数据垃圾)MySQL中的

Java 实用工具类Spring 的 AnnotationUtils详解

《Java实用工具类Spring的AnnotationUtils详解》Spring框架提供了一个强大的注解工具类org.springframework.core.annotation.Annot... 目录前言一、AnnotationUtils 的常用方法二、常见应用场景三、与 JDK 原生注解 API 的

Java controller接口出入参时间序列化转换操作方法(两种)

《Javacontroller接口出入参时间序列化转换操作方法(两种)》:本文主要介绍Javacontroller接口出入参时间序列化转换操作方法,本文给大家列举两种简单方法,感兴趣的朋友一起看... 目录方式一、使用注解方式二、统一配置场景:在controller编写的接口,在前后端交互过程中一般都会涉及

Java中的StringBuilder之如何高效构建字符串

《Java中的StringBuilder之如何高效构建字符串》本文将深入浅出地介绍StringBuilder的使用方法、性能优势以及相关字符串处理技术,结合代码示例帮助读者更好地理解和应用,希望对大家... 目录关键点什么是 StringBuilder?为什么需要 StringBuilder?如何使用 St