gpt4 book ai didi

Java 8 Streams 按可选属性分组

转载 作者:搜寻专家 更新时间:2023-11-01 02:38:31 27 4
gpt4 key购买 nike

我正在尝试对来自属性的计算值进行分组。计算值是可选的 - 更清楚一点,他是一个简化的例子:

class Foo: 
int id;
Group group;
.. some other stuff

class Group:
String groupId;
... (some other stuff)

class SomeName:
String someAttribute;

class Converter:
public Optional<SomeName> getSomenameFromGroup(Group)

我无法更改 Converter 中的方法,因为它不属于我。

我有一个 Foo 列表,我想按 SomeName 的“someAttribute”进行过滤。

例如,我有这样的东西:

Map<String, List<Foo>> fooBySomeName = 
fooList.stream().collect(Collectors
.groupingBy(foo -> {
Optional<SomeName> name =
converter.getSomenameFromGroup(foo.getGroup.getGroupId());
return name.isPresent() ? name.get().someAttribute() : "";
}));

但问题是,如果名称不在 groupingBy 语句中,我不想在我的 map 中添加任何内容。我有这样的事情:

fooBySomeNames.remove("")

我认为它可以从 map 中删除按该键分组的任何内容,但是在 groupingBy 语句中是否有更清晰或更正确的方法来执行此操作?

最佳答案

您可以使用过滤器删除条目,如下所示。

Map<String, List<Foo>> fooBySomeName = fooList.stream()
.filter(foo -> fooToSomeAttribute(foo).isPresent())
.collect(Collectors.groupingBy(foo -> fooToSomeAttribute(foo).get()));

private static Optional<String> fooToSomeAttribute(Foo foo)
{
return Optional.ofNullable(foo)
.map(Foo::getGroup)
.flatMap(new Converter()::getSomenameFromGroup)
.map(SomeName::getSomeAttribute);
}

或者,使用一对对象,您可以避免为每个 Foo 重复计算 someAttribute:

Map<String, List<Foo>> fooBySomeName = fooList.stream()
.filter(Objects::nonNull)
.map(FooAndSomeAttribute::new)
.filter(pair -> pair.getSomeAttribute().isPresent())
.collect(Collectors.groupingBy(
pair -> pair.getSomeAttribute().get(),
Collectors.mapping(
FooAndSomeAttribute::getFoo,
Collectors.toList())));

private static class FooAndSomeAttribute
{
private final Foo foo;
private final Optional<String> someAttribute;

public FooAndSomeAttribute(Foo foo)
{
this.foo = foo;
this.someAttribute = Optional.ofNullable(foo)
.map(Foo::getGroup)
.flatMap(new Converter()::getSomenameFromGroup)
.map(SomeName::getSomeAttribute);
}

public Foo getFoo()
{
return foo;
}

public Optional<String> getSomeAttribute()
{
return someAttribute;
}
}

关于Java 8 Streams 按可选属性分组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40165782/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com