草庐IT

data-stream

全部标签

java - 如何在 java 8 stream api 中使用 guava Predicates 作为过滤器

GuavaPredicates不能开箱即用作为java8流API的过滤器。例如这是不可能的:Numberfirst=numbers.stream().filter(com.google.common.base.Predicates.instanceOf(Double.class))).findFirst().get();如何将guava谓词转换为java8谓词,如下所示:publicstaticPredicatetoJava8(com.google.common.base.PredicateguavaPredicate){return(e->guavaPredicate.apply(e

java - 比 Stream.peek() 更好的方法

“peek”主要用于调试。如果我想在流中间调用流上的方法,改变流对象的状态,该怎么办。Stream.of("Karl","Jill","Jack").map(Test::new).peek(t->t.setLastName("Doe"));我能做到:Stream.of("Karl","Jill","Jack").map(Test::new).map(t->{t.setLastName("Doe");returnt;});但这看起来很丑陋。这是不应该做的事情还是有更好的方法来做到这一点?编辑:forEach可以工作,除了它是一个终端操作,所以你不能在之后继续处理流。然后我希望制作一个Co

java - 使用普通 JAVA Stream 收集 int 数组的值

在我的程序中,我尝试使用流打印排序的int数组。但是我在使用普通流时得到错误的输出。使用int流时会打印正确的详细信息。有关详细信息,请参阅下面的核心代码段。packagecom.test.sort.bubblesort;importjava.util.Arrays;importjava.util.stream.Collectors;importjava.util.stream.IntStream;publicclassBubbleSortWithRecursion{publicstaticvoidbubbleSort(int[]arr,intn){if(nnextValue){arr

java - 如何在我的 java servlet 中处理 multipart/form-data POST 请求?

我很难用我的Java应用程序服务器处理多部分/表单数据请求。据我所知,servlet3.0规范提供了诸如HttpServletRequest.getParts()之类的方法,它非常适合处理上传到我的servlet的表单数据。但是,这个方法是3.0servlet规范的一部分,我的应用服务器(Tomcat6)还不支持这个。即使使用有效的3.0web.xml文件和JavaEE6库,我在尝试调用getParts()时也会遇到以下异常:java.lang.NoSuchMethodError:javax.servlet.http.HttpServletRequest.getParts()Ljava

java - 使用 Stream 从二维整数数组中查找奇数

我正在尝试如下代码int[][]mat=newint[][]{newint[]{2,4,6},newint[]{8,9,12}};intoddInAll=Arrays.stream(mat).filter(i->i%2!=0).findFirst().getAsInt();但这给了我错误|Error:|badoperandtypesforbinaryoperator'%'|firsttype:int[]|secondtype:int|intoddInAll=Arrays.stream(mat).filter(i->i%2!=0).findFirst().getAsInt();|^---

java - Spring Data JPA 存储库 : IN-clause in derived query not working

我有一个看起来像这样的存储库:publicinterfaceUserRepositoryextendsJpaRepository{UserfindByEmailIgnoreCase(Stringemail);@Query("selectufromUseruwhereu.idin(:ids)")SetgetByIdInSet(@Param("ids")Setids);}当我调用getByIdInSet时,出现以下错误:Causedby:java.lang.IllegalArgumentException:Youhaveattemptedtosetavalueoftypeclassorg.

java - PreparedStatement : How to insert data into multiple tables using JDBC

有人能告诉我以下JDBC代码中是否需要第一个stmt.close();来针对两个不同的表执行两个不同的SQL查询吗?publicclassMyService{privateConnectionconnection=null;publicvoidsave(Bookbook){try{Class.forName("com.mysql.jdbc.Driver");connection=DriverManager.getConnection("jdbc:mysql://localhost:3306/mydb","root","password");PreparedStatementstmt=c

java - 如何使用 Java stream api 过滤 map ?

Mapmap=newHashMap();map.put(1,"f");map.put(2,"I");map.put(3,"a");map.put(4,"c");....etc现在我有一个列表:Listpicks={1,3}我想取回一个字符串列表,即在“选择”列表中找到的与键值匹配的映射值。所以,我希望取回{"f","a"}作为结果。有没有办法使用javastreamapi以优雅的方式做到这一点?当只有一个值时,我是这样做的:map.entrySet().stream().filter(entry->"a".equals(entry.getValue())).map(entry->ent

java - 使用 Stream 比较两个集合 - anyMatch

我想比较list2中的任何对象是否存在于list1中。我可以遍历两个列表并使用.contains()比较所有元素,但我想知道是否有更有效的方法。我找到了this我正在尝试实现建议的方法:Listlist1;Listlist2;booleananyMatch=list1.stream().anyMatch(x->x.equals(list2.stream()));System.out.println(anyMatch);当我这样做时,我经常得到false,即使我期望的是true。怎么会? 最佳答案 根据您的评论,您有两个列表,list

java - Spring Data - 从表中获取最后一条记录

这个问题在这里已经有了答案:GetlastrecordsorderedbydateonSpringData(2个答案)关闭4年前。我正在使用SpringDataJPA,我想从Settings表中检索最后一条记录。我有SettingsRepository以及由SpringData实现的标准方法。如何编写方法(或查询)从给定表中检索最后一行?interfaceSettingsRepositoryextendsJpaRepository{//?}