- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试使用直接来自两个不同源的两个ArrayList
的流来生成SortedMap
。我的目标是让 SortedMap
将第二个列表中的 Double
属性存储为键,将第一个列表中的对象存储为值(如果这些对象具有匹配的属性),由辅助对象检查。
到目前为止,我可以使用以下方法完成它:
SortedMap<Double, FirstObject> myMap = new TreeMap<>(Double::compareTo);
List<FirstObject> myList = firstDao.get(someId).stream()
.filter(firstobject -> secondDao.get(firstObject.getObjectId())
.stream()
.anyMatch(secondObject -> {
if (Helper.check(secondObject).matches()) {
myMap.put(
secondObject.getEfficiency(), firstObject
);
}
return Helper.check(secondObject).matches();
}))
.collect(Collectors.toList());
我用该代码生成的 myList
没有用处,但到目前为止,这是我能够填充 Map
的唯一方法。
有没有办法可以直接填充到 SortedMap
而无需生成该列表?
最佳答案
您需要使用collect
,而不是创建会导致副作用的过滤器
。
实现此目的的方法之一是创建一个中间 Map,它将 firstDao
返回的每个对象与 secondDao
返回的匹配对关联起来。
然后在中间映射的条目上创建一个流。过滤掉带有空键(没有匹配对)的条目。然后应用collect(Collectors.toMap())
。
NavigableMap<Double, FirstObject> myMap = firstDao.get(tableId).stream()
.collect(Collectors.toMap( // creates a map `Map<Optional<Double>,FirstObject>`
firstObject -> secondDao.get(firstObject.getObjectId()).stream()
.filter(secondObject -> firstObject.getAttribute().equals(secondObject.getAttribute()))
.findFirst()
.map(FirstObject::getEfficiency),
Function.identity(),
(left, right) -> left // duplicated keys would appear when there are more then one object having no matching pair (the key would be an empty optional), so we need to guard against that case by providing a merge function to resulve duplicates
))
.entrySet().stream()
.filter(entry -> entry.getKey().isPresent())
.collect(Collectors.toMap(
entry -> entry.getKey().get(), // extracting a key (efficiency)
Map.Entry::getValue, // extracting a value
(left, right) -> { throw new AssertionError("duplicates are not expected"); }, // since the source is an intermediate map we don't expect duplicates
TreeMap::new
));
解决此问题的另一种更简洁的方法是使用 Collector.of()
创建一个自定义收集器 (整体逻辑保持不变):
NavigableMap<Double, FirstObject> myMap = firstDao.get(tableId).stream()
.collect(Collector.of(
TreeMap::new, // mutable container of the collector
(NavigableMap<Double, FirstObject> map, FirstObject firstObject) ->
secondDao.get(firstObject.getObjectId()).stream() // population the mutable container
.filter(secondObject -> next.getAttribute().equals(secondObject.getAttribute()))
.findFirst()
.map(FirstObject::getEfficiency)
.ifPresent(efficiency -> map.put(efficiency, firstObject)),
(left, right) -> { left.putAll(right); return left; } // merging containers in parallel, I'm assuming that there's no duplicates and hence there's no special policy
));
旁注:当您需要 TreeMap
时,最好使用 NavigableMap
作为抽象类型。此接口(interface)扩展了 SortedMap
并提供了许多 SortedMap
无法访问的方法。
问题中提供的代码创建了通过firstDao
和以下filter<的方式检索的对象流<如果谓词很重要,
将通过以效率
添加新条目(或替换现有条目的值)来更新映射myMap
> 使用 secondDao.get()
作为源创建的流中第一次遇到匹配的对象。
.filter(firstobject -> secondDao.get().stream()
.anyMatch(secondObject -> {
if (someCondition) {
myMap.put(secondObject.getEfficiency(), firstObject);
}
return someCondition;
}))
anyMatch
- 是一个短路操作,如果有相同的id
但不同的效率
,它们将被忽略。
上述解决方案中的这段代码的行为方式完全相同:findFirst
将选择将评估 someCondition
的第一个对象为 true
(之后会单独处理具有空可选值的情况,并且可选值的 equals/hashCode
会委托(delegate)给 equals/hashCode
实现其值,因此结果中没有差异的余地)。
firstObject -> secondDao.get().stream()
.filter(secondObject -> someCondition)
.findFirst()
.map(FirstObject::getEfficiency)
我认为这是预期的行为,因为没有提到问题中提供的代码在某些方面出现故障,并且没有样本数据(可能会得出相反的结论)。
因此,上述解决方案未产生预期结果的说法与问题的当前状态相矛盾,因为它是基于原始代码的逻辑。
直到期望的结果 未指定(通过提供示例数据,或描述原始代码的问题),我认为没有可能改进答案。
关于java - 根据两个List的内容生成SortedMap,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/73361701/
我想使用 R 预定义这样的列表 DATA<-list( list(list(),list(),list()), list(list(),list(),list()), list(list(),l
如何将一个列表添加到另一个列表,返回一个列表的列表? foo :: [a] -> [a] -> [[a]] 例如,我想要的结果是: foo [1,2] [3,4] 将是 [[1,2], [3,4]]。
我还没有在这里找到类似问题的解决方案,所以我会寻求你的帮助。 有 2 个列表,其中之一是列表列表: categories = ['APPLE', 'ORANGE', 'BANANA'] test_re
这个问题不同于Converting list of lists / nested lists to list of lists without nesting (这会产生一组非常具体的响应,但无法解决
原始列表转换为 List正好。为什么原始列表的列表不能转换为 List 的列表? { // works List raw = null; List wild = raw; } {
在下面的代码中,get()被调用并将其结果分配给类型为 List> 的变量. get()返回 List>并在类型参数为 T 的实例上调用设置为 ? ,所以它应该适合。 import java.util
原始列表转换为 List正好。为什么原始列表的列表不能转换为 List 的列表? { // works List raw = null; List wild = raw; } {
在insufficiently-polymorphic 作者说: def foo[A](fst: List[A], snd: List[A]): List[A] There are fewer way
我有下面的代码有效。 class ListManipulate(val list: List, val blockCount: Int) { val result: MutableList>
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 5 年前。 Improve this ques
在 scala (2.9) 中转换列表列表的最佳方法是什么? 我有一个 list : List[List[A]] 我想转换成 List[A] 如何递归地实现这一点?或者还有其他更好的办法吗? 最佳答案
我编写了这个函数来确定给定元素是否存储在元组列表的列表中,但目前它只搜索第一个列表。我将如何搜索其余列表? fun findItem (name : command, ((x,y)::firstlis
我创建了一个类名 objectA,它有 4 个变量:约会时间;字符串文本;变量 1,变量 2 我需要创建一个 ObjectA() 列表。然后首先按时间对它们进行分组,其次按 var1,然后按 var2
我有一套说法 char={'J','A'} 和列表的列表 content = [[1,'J', 2], [2, 'K', 3], [2, 'A', 3], [3,'A', 9], [5, 'J', 9
我有以下列表 List >>> titles = new ArrayList >>> ();我想访问它的元素,但我不知道该怎么做.. 该列表有 1 个元素,它又包含 3 个元素,这 3 个元素中的
转换 List[List[Long]] 的最佳方法是什么?到 List[List[Int]]在斯卡拉? 例如,给定以下类型列表 List[List[Long]] val l: List[List[Lo
我有一个来自 Filereader (String) 的 List-List,如何将其转换为 List-List (Double):我必须返回一个包含 line-Array 的第一个 Values 的
我收集了List> 。我需要将其转换为List> 。这是我尝试过的, List> dataOne = GetDataOne(); var dataTwo = dataOne.Select(x => x
这个问题在这里已经有了答案: Cannot convert from List to List> (3 个答案) 关闭 7 年前。 我没有得到这段代码以任何方式编译: List a = new Ar
这个问题在这里已经有了答案: Cannot convert from List to List> (3 个答案) 关闭 7 年前。 我没有得到这段代码以任何方式编译: List a = new Ar
我是一名优秀的程序员,十分优秀!