草庐IT

garbage_collector_performance_tun

全部标签

java - Collectors.toMap 在与未用作值的对象不同的属性上编写合并函数

我需要创建Map来自List使用StreamAPI。persons.stream().collect(Collectors.toMap(Person::getNationality,Person::getName,(name1,name2)->name1)但在上述情况下,我想通过使用人员的年龄来解决名称属性中的冲突。有没有办法在(age1,age2)->//ifage1isgreaterthanage2returnname1,elsereturnname2行附近传递合并函数?? 最佳答案 要根据年龄选择一个人,您需要Person实例

java - Collectors.toConcurrentMap 和通过 Collectors.toMap 供应商选项将 Map 转换为 ConcurrentHashMap 之间有什么区别?

我想通过Java8Stream和Collector接口(interface)将Map转换为ConcurrentHashMap,然后是我可以使用的两个选项。第一个:Mapmb=persons.stream().collect(Collectors.toMap(p->p.age,p->p.name,(name1,name2)->name1+";"+name2,ConcurrentHashMap::new));第二个:Mapmb1=persons.stream().collect(Collectors.toConcurrentMap(p->p.age,p->p.name));哪个是更好的选择

java - 反转 Collectors.toMap 以添加到 ArrayList

我想将数字的频率放在TreeMap中,以频率作为键,并将具有该频率的数字放在ArrayList中。我有两个问题:1)我在第一个参数中收到“无法从静态上下文引用非静态方法”错误(据我所知,流引用了一个对象-发生了什么?)2)Collectors.toMap()有4个参数——似乎参数4需要用新的TreeMap初始化>,参数2可以是ArrayListadd()函数,参数3可以为null(可能)。这是怎么做到的?importjava.util.*;importjava.util.function.Function;importjava.util.stream.Collectors;public

google-app-engine - App Engine 批量加载程序下载警告 "No descending index on __key__, performing serial download"

我正在使用以下内容下载我的一种的所有实例:appcfg.pydownload_data--config_file=bulkloader.yaml--kind=ModelName--filename=ModelName.csv--url=http://appid.appspot.com/remote_api如果种类的实例数多于批量大小,那么我会收到此警告:Nodescendingindexon__key__,performingserialdownload我没有任何自定义索引,也没有任何禁用索引的属性。我“需要”做些什么来解决这个警告,还是它只是一个我可以放心忽略的警告?会影响下载速度吗

java - 尽可能在 Collectors 中使用 Characteristics.UNORDERED 重要吗?

因为我经常使用流,其中一些流处理大量数据,所以我认为预先分配一个近似大小的基于集合的收集器是个好主意,以防止昂贵的重新分配作为集合成长。所以我想出了这个,以及其他集合类型的类似方法:publicstaticCollector>toSetSized(intinitialCapacity){returnCollectors.toCollection(()->newHashSet(initialCapacity));}像这样使用SetfooSet=myFooStream.collect(toSetSized(100000));我担心的是Collectors.toSet()的实现设置了Char

java - Collectors.toMap 不编译

这段代码无法编译Listpairs=newArrayList();System.out.println(pairs.stream().collect(Collectors.toMap(x->x.split("=")[0],x->x.split("=")[1])));编译错误是:方法split(String)undefinedobject类型System.out.println(pairs.stream().collect(Collectors.toMap(x->x.split("=")[0],x->x.split("=")[1])错误));但是这个编译的很好Listpairs=newA

java - 为什么 Collectors.toList() 不适用于原始集合?

(这可能与https://stackoverflow.com/a/30312177/160137有关,但恐怕我还是不明白。所以我以这种方式问我的问题,希望它能得到答案我可以更多很容易理解。)通常当我有一个Stream时,我可以使用Collectors类中的静态方法之一将它转换为一个集合:Liststrings=Stream.of("this","is","a","list","of","strings").collect(Collectors.toList());但是,正如其他人所注意到的那样,类似的过程不适用于原始流:IntStream.of(3,1,4,1,5,9).collect

java - Collectors.toList() 中 LongStream VS Stream 的区别

为什么当我使用Collectors.toList()从LongStream获取列表时出现错误,但使用Stream时没有错误?例子:错误:Something.mapToLong(Long::parseLong).collect(Collectors.toList())正确:Something.map(Long::valueOf).collect(Collectors.toList()) 最佳答案 StreamAPI中有四个不同的类:Stream,IntStream,LongStream和DoubleStream.后三个用于处理原始值i

Performance Improvements in .NET 8 & 7 & 6 -- String【翻译】

原文:https://devblogs.microsoft.com/dotnet/performance-improvements-in-net-8/#strings-arrays-and-spans.Net8.NET8在数据处理领域有了巨大的改进,特别是在有效操作字符串,数组和Span方面。既然我们刚刚谈到了UTF8和IUtf8SpanFormattable,那就从这里开始。UTF8如前所述,现在有很多类型实现了IUtf8SpanFormattable。我注意到所有的数值原始类型,DateTime{Offset},和Guid,以及dotnet/runtime#84556,System.Ver

java - 如何在 Java 8 Stream API 中使用 Collectors.grouping 来创建 map

我第一次寻找Java8的StreamAPI。我尝试创建一个过滤器来从Map中删除元素。这是我的map:Mapm=newHashMap();我想删除值)。这是我一直在尝试的:m.entrySet().stream().filter(p->p.getValue()>0).collect(Collectors.groupingBy(s->s.getKey()));我得到一个HashMap>。所以,这不是我想要的。我也试过:m.entrySet().stream().filter(p->p.getValue()>0).collect(Collectors.groupingBy(Map::Ent