JAVA基础---Stream流

Stream流出现背景

背景

在Java8之前,通常用 fori、for each 或者 Iterator 迭代来重排序合并数据,或者通过重新定义 Collections.sorts的 Comparator 方法来实现,这两种方式对 大数量系统来说,效率不理想。

Java8 中添加了一个新的接口类 Stream,相当于高级版的 Iterator,通过Lambda 表达式对集合进行各种非常便利、高效的聚合操作(Aggregate Operation),或者大批量数据操作 (Bulk Data Operation)。Stream不仅可以通过串行的方式实现数据操作,还可以通过并行的方式处理大批量数据,提高数据的处理效率。

解释

Java 8 API添加了一个新的抽象称为流Stream,可以让你以一种声明的方式处理数据。

  1. Stream 使用一种类似用 SQL 语句从数据库查询数据的直观方式来提供一种对 Java 集合运算和表达的高阶抽象。

    select * from user where age >30

    流水线:

    空瓶子--》灌水---》盖盖子--》贴标签 --->一瓶农夫三拳

  2. Stream API可以极大提高Java程序员的生产力,让程序员写出高效率、干净、简洁的代码。

  3. 这种风格将要处理的元素集合看作一种流, 流在管道中传输, 并且可以在管道的节点上进行处理, 比如筛选, 排序,聚合等。

  4. 元素流在管道中经过中间操作(intermediate operation)的处理,最后由最终操作(terminal operation)得到前面处理的结果。

什么是Stream流

Stream(流)是一个来自数据源的元素队列并支持聚合操作

  1. <strong元素队列< strong="">元素是特定类型的对象,形成一个队列。 Java中的Stream并不会存储元素,而是按需计算。</strong元素队列<>

  2. 数据源 流的来源。 可以是集合,数组,I/O channel(nio new IO非阻塞式IO), 产生器generator 等。

  3. 聚合操作 类似SQL语句一样的操作, 比如filter, map, reduce, find, match, sorted等。

    和以前的Collection操作不同, Stream操作还有两个基础的特征:

  4. Pipelining: 中间操作都会返回流对象本身。 这样多个操作可以串联成一个管道, 如同流式风格(fluent style)。 这样做可以对操作进行优化, 比如延迟执行(laziness)和短路( short-circuiting)。

  5. 内部迭代: 以前对集合遍历都是通过Iterator或者For-Each的方式, 显式的在集合外部进行迭代, 这叫做外部迭代。 Stream提供了内部迭代的方式, 通过访问者模式(Visitor)实现。

如何生成流

在 Java 8 中, 集合接口有两个方法来生成流:

stream() − 为集合创建串行流。

parallelStream() − 为集合创建并行流。

常用方法

for each(循环遍历)

public class StreamTest {
    public static void main(String[] args) {
        List<Integer> list= Arrays.asList(1,2,-2,3,4,5,6,7,8);
        //for each
        list.stream().forEach(System.out::println);
        }
}

运行结果

map

public class StreamTest {
    public static void main(String[] args) {
        List<Integer> list= Arrays.asList(1,2,-2,3,4,5,6,7,8);
        //for each
        list.stream().forEach(System.out::println);
        //list中的每个元素都乘以3然后再打印
        list.stream()
                .map(integer -> integer*3)//map表示对什么进行操作,箭头前面为数据,箭头后面为对数据进行的操作
                .forEach(System.out::println);
        }
}

运行结果

fliter

public class StreamTest {
    public static void main(String[] args) {
        List<Integer> list= Arrays.asList(1,2,-2,3,4,5,6,7,8);
        //for each
        list.stream().forEach(System.out::println);
        //list中的每个元素都乘以3然后再打印
        list.stream()
                .map(integer -> integer*3)//map表示对什么进行操作,箭头前面为数据,箭头后面为对数据进行的操作
                .forEach(System.out::println);
        System.out.println("======================使用过滤器=============================");
        list.stream()
                .map(integer -> integer*2)
                .filter(integer -> integer>7)
                .forEach(System.out::println);
    }
}

运行结果

limit

public class StreamTest {
    public static void main(String[] args) {
        List<Integer> list= Arrays.asList(1,2,-2,3,4,5,6,7,8);
        //for each
        list.stream().forEach(System.out::println);
        //list中的每个元素都乘以3然后再打印
        list.stream()
                .map(integer -> integer*3)//map表示对什么进行操作,箭头前面为数据,箭头后面为对数据进行的操作
                .forEach(System.out::println);
        System.out.println("======================使用过滤器=============================");
        list.stream()
                .map(integer -> integer*2)
                .filter(integer -> integer>7)
                .forEach(System.out::println);
        System.out.println("======================使用限制器=============================");
        list.stream()
                .map(integer -> integer*2)
                .filter(integer -> integer>7)
                .limit(3)//限制只输出3个元素(前三个)
                .forEach(System.out::println);
    }
}

运行结果

sorted

public class StreamTest {
    public static void main(String[] args) {
        List<Integer> list= Arrays.asList(1,2,-2,3,4,5,6,7,8);
        //for each        list.stream().forEach(System.out::println);
        //list中的每个元素都乘以3然后再打印
        list.stream()
                .map(integer -> integer*3)//map表示对什么进行操作,箭头前面为数据,箭头后面为对数据进行的操作
                .forEach(System.out::println);
        System.out.println("======================使用过滤器=============================");
        list.stream()
                .map(integer -> integer*2)
                .filter(integer -> integer>7)
                .forEach(System.out::println);
        System.out.println("======================使用限制器=============================");
        list.stream()
                .map(integer -> integer*2)
                .filter(integer -> integer>7)
                .limit(3)//限制只输出3个元素(前三个)
                .forEach(System.out::println);
        System.out.println("======================使用排序器=============================");
        list.stream()
                .map(integer -> integer*2)
                .filter(integer -> integer>-100)
                .sorted()//默认从小到大排序
                .limit(6)//限制只输出3个元素(前三个)
                .forEach(System.out::println);
    }
}

运行结果

并行流与串行流

parallelStream 是流并行处理程序的代替方法。以下实例我们使用 parallelStream 来输出空字符串的数量:

Collectors

Collectors 类实现了很多归约操作,例如将流转换成集合和聚合元素。Collectors 可用于返回列表或字符串:

写在最后:流式编程是JAVA中一种很重要的编程思想,希望大家能够重视,这对提高代码效率十分有帮助。

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Python量化炒股的获取数据函数—get_concept()

查询股票所属的概念板块函数get_concept()&#xff0c;利用该函数可以查询一只或多只股票所属的概念板块&#xff0c;其语法格式如下&#xff1a; get_concept(security, dateNone)security&#xff1a;标的代码。类型为字符串&#xff0c;形式如‘000001.XSHE’&#xff0c;或…

邦注科技 模具清洗机 干冰清洗机 干冰清洗设备原理介绍

干冰清洗机&#xff0c;这款神奇的清洁设备&#xff0c;以干冰颗粒——固态的二氧化碳&#xff0c;作为其独特的清洁介质。它的工作原理可谓独具匠心&#xff0c;利用高压空气将干冰颗粒推送至超音速的速度&#xff0c;犹如一颗颗银色的流星&#xff0c;疾速喷射至待清洗的物体…

攻防世界XCTF-WEB入门12题解题报告

WEB入门题比较适合信息安全专业大一学生&#xff0c;难度低上手快&#xff0c;套路基本都一样 需要掌握&#xff1a; 基本的PHP、Python、JS语法基本的代理BurpSuite使用基本的HTTP请求交互过程基本的安全知识&#xff08;Owasp top10&#xff09; 先人一步&#xff0c;掌握W…

基准测试函数表达式--单峰函数与多峰函数

⚠申明&#xff1a; 未经许可&#xff0c;禁止以任何形式转载&#xff0c;若要引用&#xff0c;请标注链接地址。 全文共计3077字&#xff0c;阅读大概需要3分钟 &#x1f308;更多学习内容&#xff0c; 欢迎&#x1f44f;关注&#x1f440;【文末】我的个人微信公众号&#xf…

SSH和Telnet的区别

SSH&#xff08;Secure Shell&#xff09;和Telnet是两种网络协议&#xff0c;用于远程登录和管理计算机系统。但是它们有以下几个主要的区别&#xff1a; 安全性&#xff1a;SSH是一种加密的协议&#xff0c;可以向服务器传输加密的数据&#xff0c;以防止数据被窃听或篡改。而…

Arcade 用户界面滚动文本框

代码 import arcade from arcade import load_texture from arcade.gui import UIManager from arcade.gui.widgets import UITextArea, UIInputText, UITexturePaneLOREM_IPSUM ("Lorem ipsum dolor sit amet, consectetur adipiscing elit. Praesent eget pellentesqu…

探索互联网医院系统源码:在线问诊小程序开发教学

在线问诊小程序作为互联网医院系统的重要组成部分&#xff0c;为患者提供了更便捷、高效的医疗服务&#xff0c;成为了人们生活中不可或缺的一部分。今天&#xff0c;小编将带您探索互联网医院系统的源码&#xff0c;并介绍在线问诊小程序的开发教学&#xff0c;带领读者深入了…

【优质书籍推荐】Vue.js 3.x+Element Plus从入门到精通

大家好&#xff0c;我是爱编程的喵喵。双985硕士毕业&#xff0c;现担任全栈工程师一职&#xff0c;热衷于将数据思维应用到工作与生活中。从事机器学习以及相关的前后端开发工作。曾在阿里云、科大讯飞、CCF等比赛获得多次Top名次。现为CSDN博客专家、人工智能领域优质创作者。…

JavaScript+C#云LIS系统源码JQuery+EasyUI+Bootstrap云LIS系统应用于哪些行业领域?区域云LIS系统源码

JavaScriptC&#xff03;云LIS系统源码JQueryEasyUIBootstrap云LIS系统应用于哪些行业领域&#xff1f;区域云LIS系统源码 云LIS是为区域医疗提供临床实验室信息服务的计算机应用程序&#xff0c;可协助区域内所有临床实验室相互协调并完成日常检验工作&#xff0c;对区域内的检…

yo!这里是网络入门初识

目录 前言 基本概念 网络 协议 地址 网络传输流程 OSI七层模型 TCP/IP四层&#xff08;五层&#xff09;模型 流程图 数据封装&&分用 后记 前言 对于上一个专栏——Linux操作系统&#xff0c;我们学习了操作系统的基础知识以及基本的系统编程&#xff0c;其…

为什么大家都说品深茶可以抗癌

据说&#xff0c;品深茶的创始人之前是一个程序员&#xff0c;他在软件行业工作十多年&#xff0c;由于常年熬夜加班再加上抽烟喝酒等不良习惯&#xff0c;导致在一次体检中被查出患上了肾癌&#xff0c;对他来说&#xff0c;期待的财务自由还没实现&#xff0c;身体就已经完蛋…

【介绍下Selenium】

&#x1f3a5;博主&#xff1a;程序员不想YY啊 &#x1f4ab;CSDN优质创作者&#xff0c;CSDN实力新星&#xff0c;CSDN博客专家 &#x1f917;点赞&#x1f388;收藏⭐再看&#x1f4ab;养成习惯 ✨希望本文对您有所裨益&#xff0c;如有不足之处&#xff0c;欢迎在评论区提出…

leetCode63. 不同路径 II

leetCode63. 不同路径 II 题目思路 代码 class Solution { public:int uniquePathsWithObstacles(vector<vector<int>>& ob) {int n ob.size();if(!n) return 0;int m ob[0].size();vector<vector<int>> f(n,vector<int>(m));for(int i …

AI育儿教育赛道,今日头条,三分钟一篇原创,小白可做,可持续的好项目

项目简介&#xff1a; 随着人们生活水平的提高&#xff0c;越来越多的父母开始关注孩子的文化教育&#xff0c;希望他们能在学业上取得优异的成绩。许多家长在孩子还未出生时就开始注重胎教&#xff0c;为孩子创造一个充满知识和兴趣的成长环境。因此&#xff0c;育儿教育领域…

【C++算法竞赛 · 图论】树

目录 前言 树 树的定义 树的相关概念 树的遍历 1 先序遍历 2 中序遍历 3 后序遍历 前言 前两篇文章&#xff08;【C算法竞赛 图论】图论基础、【C算法竞赛 图论】图的存储&#xff09;中&#xff0c;介绍了图的相关概念与存储&#xff0c;还不了解的可以去补补课。 …

解决安装jieba失败的问题

1. 问题描述 在pycharm中通过Python Interpreter下载jieba库或者直接下载jieba压缩包等方式都无法解决import jieba报错的问题。 2. 问题解决 直接在pycharm的控制台中输入pip install jieba 下载jieba&#xff0c;当然通过这个方式下载很慢&#xff0c;所以使用镜像。 pip i…

超详细的Vue脚手架

文章目录 Node.js介绍安装快速入门控制台输出使用函数模块化编程 npm包管理器介绍命令初始化命令本地安装(了解)全局安装(掌握)批量下载淘宝npm镜像(建议使用) Webpack介绍安装快速入门方式一&#xff1a;webpack原始方式方式二&#xff1a;基于NPM方式 webpack-dev-server 开发…

redis中的集群模式

主从复制、主从同步(解决高并发读的问题) 主从同步原理&#xff1a; 1.全量同步 slave&#xff08;从节点&#xff09;每次请求数据同步会带两个参数&#xff1a;replid和offset。 replid&#xff1a;第一次请求同步时&#xff0c;replid和master的replid不一样&#xff0c;这…

公共交通无障碍设施:科技翅膀助力盲人出行新飞跃

在城市的脉络中&#xff0c;公共交通扮演着连接每一个角落的重要角色。然而&#xff0c;对于视力受限的盲人朋友而言&#xff0c;这幅繁忙而复杂的交通网络往往隐藏着诸多不易察觉的障碍。值得庆幸的是&#xff0c;随着公共交通无障碍设施的不断完善&#xff0c;以及高科技辅助…

Akamai 分布式“云+边缘”,打造下一代数字化基座

当下&#xff0c;数字化基础设施正逐步向分布式部署演化&#xff0c;云计算与边缘计算正在成为两大技术支柱。Gartner 数据显示&#xff0c;云服务占 IT 整体支出比例连年上涨&#xff0c;在过去一年已增长至12.1%&#xff1b;IDC 报告显示&#xff0c;截至2021年已有超过500亿…