草庐IT

stream_context_set_option

全部标签

java - Stream 中 "filter then map"和 "map then filter"的性能是否不同?

我想知道什么更快:按字段过滤自定义对象,然后按其字段映射,反之亦然(先映射,然后过滤)。最后,我通常想将映射的字段收集到一些Collection中。比如最简单的Person类:publicclassPerson{Stringuuid;Stringname;StringsecondName;}现在让我们有一个Listpersons.Listfiltered1=persons.stream().filter(p->"NEED_TOY".equals(p.getName())).map(Person::getName).collect(Collectors.toList());//or?Li

java - args4j : in "usage" how to sort Options manually?

在args4j中,我定义了这样的选项:@Option(name="-host",usage="hosttoconnect")@Option(name="-port",usage="portofthehost")@Option(name="-idle",usage="idle")然而,当显示帮助时,args4j总是使用字母顺序,所以它会打印-host-hosttoconnect-idle-idle-port-porttoconnect这不太方便,因为我想先显示强制选项。此外,我想自己设置选项的顺序,因为一些选项(如主机和端口)应该放在一起。如何控制args4j中选项的顺序?我发现3年前问

java - 测试调用 : how to do set up common to all test suites

有没有办法知道JUnit4测试类是否由测试套件启动?我有全局的东西,我想在所有测试之前运行(关于内存数据库),所以我想在测试服中做它。但是,我仍然希望能够在没有测试服的情况下一次启动一个测试,所以我需要知道我是否需要在测试的@Before部分初始化全局事物......有人知道吗如果它是可能的? 最佳答案 有几种方法可以实现这一点。最简单和最简单的方法是在套件的开始和结束时运行一个“测试”,它会设置您的数据库,然后设置一个全局标志。在您的@Before和@After测试中,您检查此标志,并在必要时进行设置/拆卸。@RunWith(Su

java - 何时返回 Iterable<String> 而不是 List、Set、Collection?

所以我一直在相当广泛地使用Neo4jAPI,我注意到它们几乎总是有返回Iterable而我一直认为最好返回Set、List或Collection之一,除非有令人信服的理由不这样做。设置为向用户表明它永远不会有重复的元素,当顺序很重要或包含重复元素时为List,或者当您没有策略时为Collection。与Iterable相比,我更喜欢它们,因为它们具有有用的实用程序,如.contains()、.add()等。我发现我经常需要编写代码将Iterable转换为Collection。所以我的问题是:我是否遗漏了一些重要的东西?使用Iterable而不是Collection是否有合理的理由?你什

Java 8 flatMap + Optional.of 不编译

我正在尝试使用JavaflatMapOptional。这是一个简化的示例:Listx=Arrays.asList("a","b","c");Listresult=x.stream().flatMap((val)->val.equals("b")?Optional.empty():Optional.of(val)).collect(Collectors.toList());我从编译器得到这个错误信息:Error:(10,27)java:incompatibletypes:noinstance(s)oftypevariable(s)Texistsothatjava.util.Optiona

java - 在 Java 8 中,如何在不使用 forEach 的情况下从 Stream<int[]> 获取 int 数组

如何转换Stream进入int[]不使用forEach?finalStreamstream=foos.stream().map(foos->insertQuery(contact,create)).map(create::batch).map(Batch::execute);//Batch::executewillreturntheint[] 最佳答案 使用flatMapToIntint[]result=stream.flatMapToInt(Arrays::stream).toArray();

java - 如何使用 Streams 将二维列表转换为一维列表?

我试过这段代码(list是ArrayList>):list.stream().flatMap(Stream::of).collect(Collectors.toList());但它什么也没做;该列表仍然是一个二维列表。如何将此二维列表转换为一维列表? 最佳答案 您仍然收到列表的原因是因为当您申请Stream::of它正在返回现有流的新流。那是你执行Stream::of的时候这就像有{{{1,2}},{{3,4}},{{5,6}}}然后当你执行flatMap就像这样做:{{{1,2}},{{3,4}},{{5,6}}}->flatMa

Java 8 Stream distinct 不起作用

这就是我正在做的:Listscores=Stream.concat(oldEntries.stream(),newEntries.stream()).sorted().distinct().limit(maxSize).collect(Collectors.toList());我期待一个没有任何重复项的排序列表,但有时列表中有重复项。我重写了hashCode和equals方法,我还观察到这些方法每次都返回正确的值。任何人都可以看到我的流有什么问题吗?这是我的equals()和hashCode()它们是由IDEA自动生成的:..privateintuserId;privateintlev

java - flatMap Set of Sets inside groupingBy 的优雅方式

所以我有一段代码,我在其中迭代数据列表。每一个都是一个ReportData包含带有LongcaseId的案例和一个Ruling.每个Ruling有一个或多个Payment.我想要一个Map与caseId作为键和支付集作为值(即Map>)。个案在行中不是唯一的,但个案是。换句话说,我可以有几行相同的案例,但它们会有独特的裁定。下面的代码给我一个Map>>这几乎是我想要的,但我一直在努力寻找在给定上下文中对最终集合进行flatMap的正确方法。我一直在做变通办法,使逻辑按原样使用此map正确工作,但我非常想修复算法以将付款集正确组合成一个集,而不是创建一组集。我四处搜索并没有找到相同类型迭

java - 是否可以创建在单个操作中计算其元素的 Stream 实现

问:是否可以创建Stream实现,在单个操作中对它们的元素进行计数,而不是对流中的每个元素进行计数?当我试图比较列表中的两种方法时,我想到了这个:大小()count()Stream::count终端操作计算流中元素的数量。操作的复杂度通常为O(N),这意味着子操作的数量与Stream中的元素数量成正比。List::size方法的复杂度为O(1),这意味着无论List中的元素数量如何,size()方法将在常数时间内返回。Listlist=IntStream.range(0,100).boxed().collect(toList());System.out.println(list.siz