当前位置: 首页 > news >正文

西安巨久科技网站建设浙江建设报名网站

西安巨久科技网站建设,浙江建设报名网站,做搜狗手机网站优化快,初学seo网站推广需要怎么做一、Stream 流介绍与使用场景 Stream 流介绍 java8 中的stream 与InputStream和OutputStream是完全不同的概念, stream 是用于对集合迭代器的增强#xff0c;使之完成能够完成更高效的聚合操作#xff08;过滤、排序、统计分组#xff09;或者大批量数据操作。stream 与 L…一、Stream 流介绍与使用场景 Stream 流介绍 java8 中的stream 与InputStream和OutputStream是完全不同的概念, stream 是用于对集合迭代器的增强使之完成能够完成更高效的聚合操作过滤、排序、统计分组或者大批量数据操作。stream 与 Lambda 表达式结合后编码效率大大提高可读性更强。 举例如下 // 获取所有红色苹果的总重量 appleStore.stream().filter(a - red.equals(a.getColor())) .mapToInt(w - w.getWeight()).sum() // 基于颜色统计平均重量 appleStore.stream().collect(Collectors.groupingBy(a - a.getColor(),Collectors.averagingInt(a - a.getWeight()))).forEach((k, v) - {System.out.println(k : v); });使用场景 场景一跨库join的问题 查询一个店铺的订单信息需要用到订单表与会员表 在传统数据库单一例中 可以通过jon 关联轻松实现但在分布场景中 这两张表分别存储在于 交易库 和会员库 两个实例中join不能用。只能在服务端实现其流程如下 查询订单表数据找出订单中所有会员的ID根据会员ID查询会员表信息将订单数据与会员数据进行合并 这用传统迭代方法非常繁琐而这正是stream 所擅长的。示例代码如下 // 获取所有会员ID 并去重 ListInteger ids orders.stream().map(o - o.getMemberId()).distinct().collect(Collectors.toList()); // 合并会员信息 至订单信息 orders.stream().forEach(o - {Member member members.stream().filter(m - m.getId() o.getMemberId()).findAny().get();o.setMemberName(member.getName()); });场景二N1 问题 二、Lambda 表达式 Lambda 简介 Lambda 表达式也可称为闭包它是推动 Java 8 发布的最重要新特性。Lambda 允许把函数作为一个方法的参数函数作为参数传递进方法中。Lambda 表达式可以使代码变的更加简洁紧凑。 匿名类写法 new Thread(new Runnable() {Overridepublic void run() {System.out.println(hello world);} }).start();Lambda写法 new Thread(() - System.out.println(hello world)).start();在上述例子中编译器会将 “System.out.println(“hello world”)” 编译成Runnable.run 的执行指令。因为 run 方法是Runnable接口的唯一方法代码中我们无需指明Run方法。如果Runable有多个方法是不能使用Lambda表达示的。 函数式接口 支持Lambda的接口统称函数式接口。 只有一个抽像方法的接口就是函数式接口其详细特征如下 接口中标注了 FunctionalInterface 注解接口中只有一个抽像方法会被编译器自动认识成函数式接口接口中有一个抽像方法同时包含了Object类的其它抽像方法也会被识别成抽像接口 Lambda表达式三种编写方式 expression单条语句表达式statement语句块reference方法引用 三、Stream 流执行机制 流的操作特性 stream不存储数据stream不改变源数据stream 不可重复使用 流的操作类型 stream 所有操作组合在一起即变成了管道管道中有以下两种操作 中间操作(intermediate): 调用中间操作方法会返回一个新的流。通过连续执行多个操作倒便就组成了Stream中的执行管道pipeline。需要注意的是这些管道被添加后并不会真正执行只有等到调用终值操作之后才会执行。终值操作(terminal) 在调用该方法后将执行之前所有的中间操作获返回结果结束对流的使用流的执行顺序说明其每个元素挨着作为参数去调用中间操作及终值操作而不是遍历完一个方法再遍历下一个方法。流的并行操作调用Stream.parallel() 方法可以将流基于多个线程并行执行 Stream 中的常用API及场景 方法描述操作类型filter接收一个Boolean表达示来过滤元素中间操作map将流中元素 1:1 映谢成另外一个元素中间操作mapToInt将流中元素映谢成intmapToLong、mapToDouble操作类似目的减少 装箱拆箱带来的损耗中间操作flatMap如map时返回的是一个List, 将会进一步拆分。详见flatMap示例中间操作forEach遍历流中所有元素终值操作sorted排序中间操作peek遍历流中所有元素 如forEach不同在于不会结束流中间操作toArray将流中元素转换成一个数组返回终值操作reduce归约合并操作中间操作collect采集数据返回一个新的结果 参数说明Supplier 采集需要返回的结果BiConsumerR, ? super T传递结果与元素进行合并。BiConsumerR, R在并发执行的时候 结果合并操作。详见 collec示例终值操作distinct基于equal 表达示去重中间操作max通过比较函数 返回最大值终值操作anyMatch流中是否有任一元素满足表达示终值操作allMatch流中所有元素满足表达示返回true终值操作noneMatch与allMatch 相反都不满足的情况下返回 true终值操作findFirst找出流中第一个元素终值操作of生成流生成流操作iterate基于迭代生成流生成流操作generate基于迭代生成流与iterate 不同的是不 后一元素的生成不依懒前一元素生成流操作concat合并两个相同类型的类生成流操作 举例 Testpublic void filterTest() {appleStore.stream().filter(a - a.getColor().equals(red)).forEach(a - {System.out.println(a.getColor());});}Testpublic void mapTest() {appleStore.stream().map(a - a.getOrigin()).forEach(System.out::println);}Testpublic void flatMapTest() throws IOException {StreamString lines Files.lines(new File(G:\\git\\tuling- java8\\src\\main\\java\\com\\tuling\\java8\\stream\\bean\\Order.java).toPath());lines.flatMap(a - Arrays.stream(a.split( ))).forEach(System.out::println);}Testpublic void sortedTest() {appleStore.stream().sorted((a, b) - a.getWeight() - b.getWeight()).map(a - a.getWeight()).forEach(System.out::println);}Testpublic void peekTest() {appleStore.stream().peek(a - {System.out.println(a.getId());}).map(a - a.getOrigin()).peek(System.out::println).forEach(a - {});}Testpublic void reduceTest() {// 找出最重的那个苹果appleStore.stream().reduce((a, b) - a.getWeight() b.getWeight() ? a : b).ifPresent(a - {System.out.println(a.getWeight());});}Testpublic void collectTest() {// 将结果转换成id作为key mapInteger,AppleHashMapInteger, Apple map appleStore.stream().collect(HashMap::new, (m, a) - m.put(a.getId(), a), (m1, m2) - m1.putAll(m2));map.forEach((k, v) - {System.out.println(k);System.out.println(v);});// MapString,ListApple// 基于颜色分组 并获取其平均重量}Collectors 中的常用API及场景 方法描述toList转换成listtoMap转换成mapgroupingBy统计分组averagingInt求平均值summingInt求总值maxBy获取最大值 举例: // 获得所有颜色苹果的平均重量 Test public void groupByTest() {CollectorApple, ?, MapString, Double groupCollect Collectors.groupingBy((Apple a) - a.getColor(), Collectors.averagingInt((Apple a) - a.getWeight()));appleStore.stream().collect(groupCollect).forEach((k, v) - {System.out.println(k : v);});}流的关闭机制 一般情况使用完流之后不需要调用 close 方法进行关闭除非是使用channel FileInputStream 这类的操作需要关闭,可调用 java.util.stream.BaseStream#onClose() 添加关闭监听。
http://www.pierceye.com/news/925110/

相关文章:

  • 牛商网做的包装盒网站怎么在门户网站上发布
  • 北京网络公司建站成品app直播源码下载
  • 帮忙建站的公司百度收录好的网站排名
  • 芯火信息做网站怎么样郑州网站建设老牌公司
  • 龙华营销型网站建设在线生成短链接网址
  • 深圳做公司网站关键词规划师工具
  • 长春市建设信息网站sem代运营推广公司
  • 宜昌网站建设平台有经验的盐城网站开发
  • wordpress 众筹网站模板wordpress首页只显示一篇文章
  • 嘉兴seo网站推广网页设计与制作课程结构
  • 江苏 网站 备案百度站长之家工具
  • 新加坡 网站建设专业简历制作网站有哪些
  • 河北外贸网站建设大连建设网球场价格
  • 北京企业网站制作哪家好新余商城网站建设
  • 网站建设对客户的优势单位建设网站的目的
  • seo网站建站公司的主页珠江夜游微信公众号
  • 建筑人才网 中高端招聘网站专业网站开发开发
  • 江门官网建站公司wordpress get_tax_meta
  • 云南省建设系统网站wordpress wdlog主题
  • 做医疗网站颜色选择网站改版301怎么做
  • 淘宝网站建设步骤做网络网站需要三证么
  • 免费网站域名注册申请视频网站开发策划书
  • 如何在社交网站做销售无锡做网站企业
  • 网站建设首选唯美谷wordpress小程序编辑
  • openwrt 网站开发北京建机职业技能鉴定中心官网
  • 莱芜新站优化wordpress打卡签到领红包
  • wordpress 网站上传到服务器免费在线自助建站
  • 连云港网站优化公司网站优化竞争对手分析
  • 网页设计案例图片网站优化如何收费
  • 个人网站包含哪些内容昆明建企业网站多少钱