集合的进阶

news2025/1/21 18:47:25

不可变集合

  • 创建不可变的集合

    • 在创建了之后集合的长度内容都不可以变化

      image-20231011162508117

  • 静态集合的创建在list ,set ,map接口当中都可以获取不可变集合

方法名称说明
static list of(E …elements)创建一个具有指定元素集合list集合对象
staticlist of(E…elements)创建一个具有指定元素的set集合
static<k,v> Map<k,v> of(E…elements)创建一个具有指定元素的Map集合
  • 这个集合是不能删除和修改

  • List集合

/*不能添加修改操作*/
List<String> list = List.of("lishi", "changff", "zhangshan", "wangshang");
      list.remove("lishi");
      list.add("shuxili");
      list.set(0,"bbbb");

image-20231011195529380

  • set集合
  • 注意事项:信息不能重复
package ImmutableDemo;

import java.util.Iterator;
import java.util.Set;

public class Demo2  {
    public static void main(String[] args) {
        Set<String> s=Set.of("lishi", "changff", "zhangshan", "wangshang","dkjkjf");
        Iterator<String> it = s.iterator();
        while (it.hasNext() ) {
            System.out.println(it.next());
        }
        System.out.println("---------------");

        System.out.println("---------------");
//        s.remove("lishi");
//        s.add("shuxili");

    }
}

image-20231011204058727

  • map集合
  • 注意事项:键值对信息不能重复
package ImmutableDemo;

import java.util.Map;
import java.util.Set;

public class Demo3 {
    public static void main(String[] args) {
        Map<String, String> mapDeom = Map.of("南京", "1000", "北京", "10000", "上海", "8000");
        Set<String> keySet = mapDeom.keySet();
        for (String s : keySet) {
            System.out.println(s);
            System.out.println(mapDeom.get(s));
        }
        System.out.println("---------");
        Set<Map.Entry<String, String>> entries = mapDeom.entrySet();
        for (Map.Entry<String, String> entry : entries) {
            String key = entry.getKey();
            String value = entry.getValue();
            System.out.println(key + "=" + value);
        }
        
    }
}

  • Map

由于map集合的特殊,还有一种方法为Map.ofEntries( )方法可以传递多个键值对 对象

package ImmutableDemo;

import java.util.HashMap;
import java.util.Map;
import java.util.Set;

public class Demo4  {
    public static void main(String[] args) {
        HashMap<String,String> h =new HashMap<>();
        h.put("aaa","111");
        h.put("bbb","222");
        h.put("ccc","333");
        h.put("ddd","444");
        h.put("eee","555");
        /*先获取键值对,对像*/
        Set<Map.Entry<String, String>> entries = h.entrySet();
        Map.Entry[] array = entries.toArray(new Map.Entry[0]);/*先将键值对对象转化为数组,0长度不会影响,在底层会自动比较,
                                                                然后转成集合的长度*/

        /*创建不可变集合*/
        Map map = Map.ofEntries(array);/*可变集合底层是一个数组,可以将数组直接传过去*/
//        map.put("fff","777");
//        map.remove("aaa");
        /*简写*/
        Map<Object, Object> map1 = Map.ofEntries(h.entrySet().toArray(new Map.Entry[0]));
    }
}

image-20231012191153662

总结:

  • 特点:

    定义完成后不可以进行增删改

  • 如何创建不可变集合

image-20231013143055418

  • 三种方式的细节
    image-20231013143315202

Stream流:

  • 思想:工厂流水线,每个负责一项功能,结合lambda表达式来简化对数组的操作

  • Stream流的使用步骤:
    1.得到一条Stream流,并添加数据
    2.使用中间方法对流水线进行操作
    3.使用终结方法结束对Stream的操作例如 sout

    获取方法方法名说明
    单列集合default Stream stream()Collection 中的默认方法
    双列集合无法直接使用stream流
    数组Public static StramStream(T[] array)Arrays工具类中的静态方法调用
    一堆零散数据public staticStream of(T…value)Stream接口中的静态方法
    • 单列集合

        public static void main(String[] args) {
              /*单列集合直接调用,list是collections的实现类*/
              ArrayList<String> list =new ArrayList<>();
              Collections.addAll(list,"A","B","C","E","F","G");
              list.stream().forEach(s -> System.out.println(s ));
          }
      
      • 双列集合
        注意事项:不能直接使用,必须转化为单列结合最后(keyset,entery)
        public static void main(String[] args) {
            HashMap<String,Integer> ha =new HashMap<>();
            ha.put("aaa",1);
            ha.put("bbb",2);
            ha.put("ccc",3);
            ha.put("ddd",4);
            ha.put("eee",5);
            /*获取键值 */
            ha.keySet().stream().forEach(s -> System.out.println(s));
            System.out.println();
            /*获取键值对 对象,*/
            ha.entrySet().stream().forEach(stringIntegerEntry -> System.out.println(stringIntegerEntry));
        }		
    
    • 数组

      注意事项:不能直接使用需要借助工具类arrays中的stream流

       /*数组*/
          public static void main(String[] args) {
              int[] arr = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10};
              String [] st ={"aaa","bbb","ccc"};
              /*获取stream流*/
              Arrays.stream(arr).forEach(s-> System.out.println(s));
              System.out.println();
              Arrays.stream(st).forEach(s1 -> System.out.println(s1));
          }	
      
    • 零散数据
      注意事项:数据的类型必须一致,在添加引用类型的数组是可以直接使用,但是基本数据类型的数组是不能使用的会吧整个数组当成一个元素直接传递到steam流中

      public static void main(String[] args) {
              Stream.of(1,2,3,4,5,6,7,8,9).forEach(s-> System.out.println(s));
          }
      

image-20231013165357994

stream流中的中间方法:

image-20231015144806477

  • Filter 过滤
    注意事项:stream流在使用一次后就自动关闭,不能在下面接着使用,建议链式编程
    在stream流中修改了数据,原来集合里面的数据不会发生改变
ArrayList<String> list = new ArrayList<>();
        Collections.addAll(list, "aaa", "bbb", "ccc", "ddd", "eee");
        list.stream().filter(new Predicate<String>() {
            @Override
            public boolean test(String s) {
                /*true:留下  false:舍弃*/
                return s.startsWith("a");
            }
        }).forEach(s -> System.out.println(s));
        /*简化*/
        list.stream().filter(s -> s.startsWith("a")).forEach(s -> System.out.println(s));
  • Limit 获取前几个元素,limit(个数)

      /*limit获取前几元素,不是索引是元素*/
            list.stream().limit(4)
                    .forEach(s -> System.out.println(s));
    
    
  • skip 跳过前几个元素,skip(个数)

    /*skip跳过前几个元素*/
            list.stream().skip(2)
                    .forEach(s -> System.out.println(s));
    

    练习:

    /*练习获取其中3-4*/
            list.stream().limit(4)
                    .skip(2)
                    .forEach(s -> System.out.println(s));
    
            System.out.println();
    
            list.stream().skip(2)
                    .limit(2)
                    .forEach(s -> System.out.println(s));
            System.out.println( );
    
    • distinct 去重复,在底层是hashset去重复

       /*去重复*/
              list1.stream().distinct().forEach(s -> System.out.println(s));/*引用数据类型可以直接,自定义的对象需要重写hascode和equales方法*/
      
      

      image-20231015113843368

    • Concat 流合并
      **注意事项:**类型一致,不会提升类型,不一致会提升到俩流的父类,不能使用单独流的特有功能

 /*流合并,类型一致,不会提升类型,不一致会提升到俩流的父类,不能使用单独流的特有功能*/
        Stream.concat(list1.stream().distinct(),list.stream())
                .forEach(s -> System.out.println(s));

Map 流的转换:

 /*流的转换*/
        list2.stream().map(new Function<String, Integer>() {
            /*string表示流里面原来就有的数据
            * integer表示的是要转换了之后的类型*/
            @Override
            public Integer apply(String s) {
                String[] split = s.split("-");/*切割方法split*/
                String s1 = split[1];
                int i = Integer.parseInt(s1);/*integer中的转换方法*/
                return i;
            }
        }).forEach(s -> System.out.println(s));
        System.out.println("================================");
        /*简化*/
        list2.stream().map(s -> Integer.parseInt(s.split("-")[1])).forEach(s-> System.out.println(s));

终结方法:

image-20231015144922634

  • 遍历
/*遍历方式*/
        list2.stream().forEach(s -> System.out.println(s));
  • 统计

    /*将Stream流中的数据进行统计*/
            System.out.println(list2.stream().distinct().count());
    
  • 收集流中的数据放到数组中

    String[] array = list2.stream().toArray(new IntFunction<String[]>() {
            @Override
            public String[] apply(int value) {
                return new String[value];
            }
        });
        System.out.println(Arrays.toString(array));

        /*简化*/
        String[] array1 = list2.stream().toArray(value -> new String[value]);
        System.out.println(Arrays.toString(array));
  • 收集流中的数据放到集合里面

    注意事项:

    lis集合是不会去重复的

    set集合是会去重复的

    map里面的键值对不能重复

    /*list*/
            List<String> collect = list2.stream()
                    .filter(s -> "男".equals(s.split("-")[2]))
                    .collect(Collectors.toList());
            System.out.println(collect);
            /*set*/
            Set<String> collect1 = list2.stream()
                    .filter(s -> "男".equals(s.split("-")[2]))
                    .collect(Collectors.toSet());
            System.out.println(collect1);
    
            /*迭代器遍历*/
            Iterator<String> iterator = collect.iterator();
            while (iterator.hasNext()) {
                System.out.println(iterator.next());
            }
            /*增强for*/
            for (String s : collect) {
                System.out.println(s);
            }
            /*foreach*/
            collect.forEach((s)-> {  System.out.println(s); });
    
            /*收集到map集合当中注意键值对不能重复*/
            Map<String, Integer> mapcollect = list2.stream()
                    .filter(s -> "男".equals(s.split("-")[2]))
                    /*在map集合里面要传递2个数据,键的获取规则,值的获取规则*/
                    /*在键或者值里面有2个类型第一个表示流里面的类型,第二个表示键或者值里面的类型,他们是交叉对应的*/
                    .collect(Collectors.toMap(new Function<String, String>() {
                        @Override
                        public String apply(String s) {
                            return s.split("-")[0];
                        }
                    }, new Function<String, Integer>() {
                        @Override
                        public Integer apply(String s) {
                            return Integer.parseInt(s.split("-")[1]);
                        }
                    }));
     				/*简化*/
            Map<String, Integer> mapcollect2 = list2.stream()
                    .filter(s -> "男".equals(s.split("-")[2]))
                    .collect(Collectors.toMap(
                            s -> s.split("-")[0]
                            ,
                            s -> Integer.parseInt(s.split("-")[1])
                    ));
            System.out.println(mapcollect2);
    
            System.out.println(mapcollect);
    

总结:

image-20231015173045971

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1095144.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

51系列—基于51单片机的RS232通信示例

一、目录 1、51单片机串口通信的应用 2、PC控制单片机IO口输出 3、51单片机控制实训指导及综合应用实例 4、51单片机给计算机发送数据 二、实验任务 单片机串口通信的应用&#xff0c;通过串口&#xff0c;我们的个人电脑和单片机系统进行通信。个人电脑作为上位机&#xff…

高能整理,性能测试-寻找TPS性能拐点与脚本Error报错排查(超细)

目录&#xff1a;导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结&#xff08;尾部小惊喜&#xff09; 前言 寻找tps性能拐点 …

DirectX3D 正交投影学习记录

所谓正交投影变换&#xff0c;就是已知盒状可视空间内任意点坐标(x,y,z)&#xff0c;求解垂直投影到xy平面的对应点坐标。 按照这个定义&#xff0c;xyz坐标系本身就是正交坐标系&#xff0c;盒状可视空间内任意点的坐标(x,y,z)投影到(x,y)平面&#xff0c;只要简单地丢弃z坐标…

3、Linux下安装

以下操作仅限于rh系列:支持rpm/yum安装方式&#xff0c;不支持deb/apt安装方式。 以下操作仅限于rh系列&#xff1a;支持rpm/yum安装方式&#xff0c;不支持 deb/apt安装方式。 1、在线下载安装包&#xff1a; wget https://downloads.mysql.com/archives/get/p/23/file/ m…

华为云云耀云服务器L实例评测|企业项目最佳实践之计划任务与Queue队列实践 (十)

十一、计划任务与Queue队列实践&#xff1a; 1. 计划任务&#xff1a; Linux环境下定时或者周期性的执行一些任务通常由cron这个守护进程来完成&#xff0c;这是一个系统自带的相对也比较方便的系统工具。 sudo apt-get install cron // 默认自带目录结构&#xff1a; 目录说…

leetcode-198.打家劫舍

1. 题目 2. 解答 dp[i]表示第i个位置的偷窃最大金额&#xff1b; room[i]表示第i间房间的现金&#xff1b; dp[0] room[0]; dp[1] max(room[0], room[1]); dp[i] max(dp[i-1], dp[i-2] room[i]); #include <stdio.h>int max(int a, int b) {return a > b? a:b;…

股票价格预测 | Python实现基于LSTM与Transfomer的股票预测模型(pytorch)

文章目录 效果一览文章概述LSTM模型原理时间序列模型从RNN到LSTMLSTM预测股票模型实现结语程序设计参考资料效果一览 文章概述 基于LSTM与Transfomer的股票预测模型 股票行情是引导交易市场变化的一大重要因素,若能够掌握股票行情的走势,则对于个人和企业的投资都有巨大的帮…

升级包版本之后Reflections反射包在springboot jar环境下扫描不到class排查过程记录

&#x1f4e2;&#x1f4e2;&#x1f4e2;&#x1f4e3;&#x1f4e3;&#x1f4e3; 哈喽&#xff01;大家好&#xff0c;我是「奇点」&#xff0c;江湖人称 singularity。刚工作几年&#xff0c;想和大家一同进步&#x1f91d;&#x1f91d; 一位上进心十足的【Java ToB端大厂…

win11的右键菜单改成win10的样子

在终端复制一下命令 reg add “HKCU\Software\Classes\CLSID{86ca1aa0-34aa-4e8b-a509-50c905bae2a2}\InprocServer32” /f /ve 回车&#xff0c;会显示成功 再重启资源管理器。这步必须执行&#xff0c;否则是成功的&#xff0c;或者可能重启电脑会成功&#xff0c;但是我没有…

使用Vscode开发C#没有代码提示问题

很多小伙伴在使用Vscode去编写C#脚本的时候会发现没有代码提示&#xff0c;这样你的敲代码速度会变的很慢&#xff01; 错误使用方法 直接把C#脚本拖入到Vscode中进行编写&#xff0c;这样是不会有代码提示的&#xff01; 正确打开办式 Edit&#xff08;编辑&#xff09;…

解决 vscode使用Prettier格式化js文件报错:Cannot find module ‘./parser-babylon‘

报错如下&#xff1a; ["ERROR" - 11:48:58] Error formatting document. ["ERROR" - 11:48:58] Cannot find module ./parser-babylon Require stack: - d:\VueCode\VueProject\myqqmusic\node_modules\prettier\index.js - c:\Users\Administrator.SKY-2…

ARM汇编学习录 2 - 编码分析

本文记录笔者学习对应汇编指令相关编码知识 ARM32 首先阅读基础概念&#xff1a; ARM-instruction-set-encoding A32指令全部是32位且是4字节地址对齐. 位域如下 如何理解4字节地址对齐和指令长度&#xff1f; 0000139c <_start_main>:139c: e92d4800 …

pyqt5-tools的安装(深度学习)

本篇主要解决上篇深度学习pyqt安装失败的问题 PyQt是一个创建GUI应用程序的工具包。它是Python编程语言和Qt库的成功融合。Qt库是最强大的库之一。PyQt是由Phil Thompson 开发。在使用labelimg对图片做标签时&#xff0c;需要用到pyqt5-tools工具&#xff0c;尝试以下下载方式&…

06在IDEA中创建Java和Web工程,了解不同工程下的类路径,在IDEA中执行Maven命令

创建Java/Web模块 类路径的概述 IDEA中普通java项目中类路径的开始就是以src目录开始的路径,编译后的字节码文件和配置文件最终都会放在out目录下 Maven生成的目录结构中src/main目录下的java和resources目录都可以看作类路径的开始,编译后的字节码文件或资源文件会放在targ…

车辆车型识别系统python+TensorFlow+Django网页界面+算法模型

一、介绍 车辆车型识别系统。本系统使用Python作为主要开发编程语言&#xff0c;通过TensorFlow搭建算法模型网络对收集到的多种车辆车型图片数据集进行训练&#xff0c;最后得到一个识别精度较高的模型文件。并基于该模型搭建Django框架的WEB网页端可视化操作界面。实现用户上…

设计模式再探——适配器模式

目录 一、背景介绍二、思路&方案三、过程1.适配器模式简介2.适配器模式的类图3.适配器模式代码4.适配器模式&#xff0c;类适配器模式和对象的对比5.适配器模式终极奥秘 四、总结五、升华 一、背景介绍 最近公司在对业务模型做构建的时候&#xff0c;涉及到和三方系统的对…

后厂村路灯:【干货分享】AppleDevelop苹果开发者到期重置

1.设备中提示&#xff1a; Before adding new devices, make sure your device list is updated for the new membership year. You have the option to remove devices from your list. 在添加新设备之前&#xff0c;请确保您的设备列表已针对新的会员年度进行了更新。您可以…

GP与LP的区别,有限责任、无限责任、无限连带责任

GP与LP的区别 GP是General Partner / 普通合伙人&#xff08;英文直译&#xff09; LP是Limited Partner / 有限合伙人&#xff08;英文直译&#xff09; GP和LP是经常出现在私募股权投资中的词汇&#xff0c;其实私募股权呢就是大家合力干一件事。很多时候&#xff0c;一个…

怎样在线修剪音频文件了?【免费,无须注册】

怎样在线修剪音频文件了&#xff1f; 推荐一个免费网址&#xff0c;且不用任何注册&#xff0c;直接可以使用 https://mp3cut.net/cn/ 上传音频文件&#xff0c; 拖动前后滚动条&#xff0c;对音频文件进行修剪。 修剪完成&#xff0c;可以保存如下格式 enjoy!! 作者简介…

[LeetCode周赛复盘] 第 115 场双周赛20231014

[LeetCode周赛复盘] 第 115 场双周赛20231014 一、本周周赛总结100095. 上一个遍历的整数1. 题目描述2. 思路分析3. 代码实现 100078. 最长相邻不相等子序列 I1. 题目描述2. 思路分析3. 代码实现 100077. 最长相邻不相等子序列 II1. 题目描述2. 思路分析3. 代码实现 100029. 和…