我正在尝试使用 Java 8 Stream
s 在 LinkedList
中查找元素。但是,我想保证只有一个匹配过滤条件。
拿这个代码:
public static void main(String[] args) {
LinkedList<User> users = new LinkedList<>();
users.add(new User(1, "User1"));
users.add(new User(2, "User2"));
users.add(new User(3, "User3"));
User match = users.stream().filter((user) -> user.getId() == 1).findAny().get();
System.out.println(match.toString());
}
static class User {
@Override
public String toString() {
return id + " - " + username;
}
int id;
String username;
public User() {
}
public User(int id, String username) {
this.id = id;
this.username = username;
}
public void setUsername(String username) {
this.username = username;
}
public void setId(int id) {
this.id = id;
}
public String getUsername() {
return username;
}
public int getId() {
return id;
}
}
此代码根据他们的 ID 找到 User
。但是不能保证有多少 User
匹配过滤器。
将过滤线更改为:
User match = users.stream().filter((user) -> user.getId() < 0).findAny().get();
会抛出一个 NoSuchElementException
(好!)
不过,如果有多个匹配项,我希望它会引发错误。有没有办法做到这一点?
原文由 ryvantage 发布,翻译遵循 CC BY-SA 4.0 许可协议
创建自定义
Collector
我们使用
Collectors.collectingAndThen
来构造我们想要的Collector
通过Collectors.toList()
收集器在List
中收集我们的对象。IllegalStateException
如果list.size != 1
。用作:
然后,您可以根据需要自定义这个
Collector
,例如在构造函数中将异常作为参数提供,调整它以允许两个值等等。另一种——可以说不那么优雅——的解决方案:
您可以使用涉及
peek()
和AtomicInteger
的“解决方法”,但实际上您不应该使用它。您可以做的只是将其收集在
List
中,如下所示: