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

相关文章

springboot集成easypoi导出word换行处理过程

《springboot集成easypoi导出word换行处理过程》SpringBoot集成Easypoi导出Word时,换行符n失效显示为空格,解决方法包括生成段落或替换模板中n为回车,同时需确... 目录项目场景问题描述解决方案第一种:生成段落的方式第二种:替换模板的情况,换行符替换成回车总结项目场景s

SpringBoot集成redisson实现延时队列教程

《SpringBoot集成redisson实现延时队列教程》文章介绍了使用Redisson实现延迟队列的完整步骤,包括依赖导入、Redis配置、工具类封装、业务枚举定义、执行器实现、Bean创建、消费... 目录1、先给项目导入Redisson依赖2、配置redis3、创建 RedissonConfig 配

SpringBoot中@Value注入静态变量方式

《SpringBoot中@Value注入静态变量方式》SpringBoot中静态变量无法直接用@Value注入,需通过setter方法,@Value(${})从属性文件获取值,@Value(#{})用... 目录项目场景解决方案注解说明1、@Value("${}")使用示例2、@Value("#{}"php

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建

线上Java OOM问题定位与解决方案超详细解析

《线上JavaOOM问题定位与解决方案超详细解析》OOM是JVM抛出的错误,表示内存分配失败,:本文主要介绍线上JavaOOM问题定位与解决方案的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录一、OOM问题核心认知1.1 OOM定义与技术定位1.2 OOM常见类型及技术特征二、OOM问题定位工具

PHP轻松处理千万行数据的方法详解

《PHP轻松处理千万行数据的方法详解》说到处理大数据集,PHP通常不是第一个想到的语言,但如果你曾经需要处理数百万行数据而不让服务器崩溃或内存耗尽,你就会知道PHP用对了工具有多强大,下面小编就... 目录问题的本质php 中的数据流处理:为什么必不可少生成器:内存高效的迭代方式流量控制:避免系统过载一次性

基于 Cursor 开发 Spring Boot 项目详细攻略

《基于Cursor开发SpringBoot项目详细攻略》Cursor是集成GPT4、Claude3.5等LLM的VSCode类AI编程工具,支持SpringBoot项目开发全流程,涵盖环境配... 目录cursor是什么?基于 Cursor 开发 Spring Boot 项目完整指南1. 环境准备2. 创建

Spring Security简介、使用与最佳实践

《SpringSecurity简介、使用与最佳实践》SpringSecurity是一个能够为基于Spring的企业应用系统提供声明式的安全访问控制解决方案的安全框架,本文给大家介绍SpringSec... 目录一、如何理解 Spring Security?—— 核心思想二、如何在 Java 项目中使用?——

SpringBoot+RustFS 实现文件切片极速上传的实例代码

《SpringBoot+RustFS实现文件切片极速上传的实例代码》本文介绍利用SpringBoot和RustFS构建高性能文件切片上传系统,实现大文件秒传、断点续传和分片上传等功能,具有一定的参考... 目录一、为什么选择 RustFS + SpringBoot?二、环境准备与部署2.1 安装 RustF

springboot中使用okhttp3的小结

《springboot中使用okhttp3的小结》OkHttp3是一个JavaHTTP客户端,可以处理各种请求类型,比如GET、POST、PUT等,并且支持高效的HTTP连接池、请求和响应缓存、以及异... 在 Spring Boot 项目中使用 OkHttp3 进行 HTTP 请求是一个高效且流行的方式。