草庐IT

streamed

全部标签

一文读懂函数式接口、Lambda表达式、Stream

前言• Java8中引入很多有意思的新特性,本篇文章我们来聊聊其中三个比较重要的特性:函数式接口、Lambda表达式、Stream流,我们分别从示例用法、底层原理、最佳实践三个方面来了解这些特性。版本• JDK8函数式接口定义• 函数式接口是Java8引入的一种接口,它只包含一个抽象方法。函数式接口的存在是为了支持Lambda表达式,使得我们可以使用更简洁、更灵活的方式编写匿名函数。@FunctionalInterfaceinterfaceCalculator{intadd(inta,intb);defaultintsubtract(inta,intb){returna-b;}staticin

相当于 LINQ SelectMany() 的 Java Stream

什么是Java8Stream相当于LINQ的SelectMany?例如,在C#中,如果我有Dictionary>tags我想变成IEnumerable(字典中所有标签的平面枚举),我会做tags.SelectMany(kvp=>kvp.Value).是否有一个Java等价于Map>那会产生一个Stream? 最佳答案 您正在寻找flatMapmap中包含的所有值:Map>map=newHashMap();Streamstream=map.values().stream().flatMap(List::stream);此代码首先检索m

java - 是否可以使用 Kafka Streams 访问消息 header ?

加上Headers对于Kafka0.11中的记录(ProducerRecord&ConsumerRecord),在使用KafkaStreams处理主题时是否可以获取这些header?当在KStream上调用类似map的方法时,它提供记录的key和value的参数,但没有我可以看到访问headers的方式。如果我们可以在ConsumerRecord上map就好了。例如KStreamBuilderkStreamBuilder=newKStreamBuilder();KStreamstream=kStreamBuilder.stream("some-topic");stream.map((k

java - iterable.forEach() 和 iterable.stream().forEach() 的区别

这个问题在这里已经有了答案:WhatisdifferencebetweenCollection.stream().forEach()andCollection.forEach()?(5个答案)关闭8年前。看起来我可以直接在我的集合上调用list.forEach(a->a.stuff()),而不是list.stream().forEach(a->a.stuff())。我什么时候会使用一个而不是另一个(parallelStream()除了..)?

java - 为什么 Stream.flatMap 不能接受一个集合?

以下面的数据类为例:classCountry{Listregions=newArrayList();ListgetRegions(){returnregions;}}classRegion{StringgetName(){return"somename";}}假设我有一个国家列表Listcountries=newArrayList();我想将它们流式传输到它们的区域和它们相应的名称,我想执行以下操作:countries.stream().flatMap(Country::getRegions).map(Region::getName)...但是该代码无法编译,因为“getRegions

java - 使用 Stream api 聚合嵌套列表

假设我有一个Shelf类,每个Shelf都有多个Book。publicclassShelf{privateStringshelfCode;privateArrayListbooks;//addgetters,settersetc.}publicclassBook{privateStringtitle;}现在,假设通过某种方法我有一个List的Shelf,每个都包含一些书。如何使用stream将所有书籍收集到此列表?Listshelves=newArrayList();Shelfs1=newShelf();s1.add(newBook("book1"));s1.add(newBook("

java - 在 Java 中使用 Optional 和 Streams

我试图重构旧代码以使用流,我的第一个方法是:publicvoidrun()throwsIOException{Files.list(this.source).filter(Images::isImage).map(Image::new).filter(image->image.isProportional(this.height,this.width)).map(image->image.resize(this.height,this.width)).forEach(image->Images.write(image,this.destination));}这不是编译,因为newIma

java - 通过 Streams 并行执行多个查询

我有以下方法:publicStringgetResult(){ListserversList=getServerListFromDB();ListappList=getAppListFromDB();ListuserList=getUserFromDB();returngetResult(serversList,appList,userList);}在这里,我依次调用三个方法,依次访问数据库并获取结果,然后对从数据库访问中获得的结果进行后处理。我知道如何通过使用Threads同时调用这三种方法。但我想使用Java8ParallelStream来实现这一点。有人可以指导我如何通过并行流实

Java 8 流 IllegalStateException : Stream has already been operated on or closed

我正在尝试使用StreamAPI生成Order实例。我有一个创建订单的工厂函数,一个DoubleStream用于初始化订单金额。privateDoubleStreamdoubleStream=newRandom().doubles(50.0,200.0);privateOrdercreateOrder(){returnnewOrder(doubleStream.findFirst().getAsDouble());}@Testpublicvoidtest(){StreamorderStream=Stream.generate(()->{returncreateOrder();});or

java - 使用 Collection.stream 按特定属性动态分组

我正在尝试使用Java8Collection-Stream按多个属性对对象列表进行分组。这很好用:publicclassMyClass{publicStringtitle;publicStringtype;publicStringmodule;publicMyClass(Stringtitle,Stringtype,Stringmodule){this.type=type;this.title=title;this.module=module;}}Listdata=newArrayList();data.add(newMyClass("1","A","B"));data.add(new