相关疑难解决方法(0)

你能将一个流分成两个流吗?

我有一个由Java 8流表示的数据集:

Stream<T> stream = ...;
Run Code Online (Sandbox Code Playgroud)

我可以看到如何过滤它以获得随机子集 - 例如

Random r = new Random();
PrimitiveIterator.OfInt coin = r.ints(0, 2).iterator();   
Stream<T> heads = stream.filter((x) -> (coin.nextInt() == 0));
Run Code Online (Sandbox Code Playgroud)

我还可以看到如何减少此流以获得,例如,两个列表代表数据集的两个随机半部分,然后将它们转换回流.但是,有没有直接的方法从最初的流生成两个流?就像是

(heads, tails) = stream.[some kind of split based on filter]
Run Code Online (Sandbox Code Playgroud)

感谢您的任何见解.

java java-8 java-stream

129
推荐指数
7
解决办法
8万
查看次数

在Java流中,窥视真的只用于调试吗?

我正在阅读有关Java流和发现新事物的内容.我发现的新事物之一是peek()功能.几乎所有我读过的内容都说它应该用来调试你的Streams.

如果我有一个Stream,每个帐户都有一个用户名,密码字段以及login()和loggedIn()方法,该怎么办?

我也有

Consumer<Account> login = account -> account.login();
Run Code Online (Sandbox Code Playgroud)

Predicate<Account> loggedIn = account -> account.loggedIn();
Run Code Online (Sandbox Code Playgroud)

为什么会这么糟糕?

List<Account> accounts; //assume it's been setup
List<Account> loggedInAccount = 
accounts.stream()
    .peek(login)
    .filter(loggedIn)
    .collect(Collectors.toList());
Run Code Online (Sandbox Code Playgroud)

现在据我所知,这完全符合它的目的.它;

  • 获取帐户列表
  • 尝试登录每个帐户
  • 过滤掉任何未登录的帐户
  • 将登录的帐户收集到新列表中

做这样的事情的缺点是什么?有什么理由我不应该继续吗?最后,如果不是这个解决方案呢?

其原始版本使用.filter()方法如下;

.filter(account -> {
        account.login();
        return account.loggedIn();
    })
Run Code Online (Sandbox Code Playgroud)

java peek java-8 java-stream

115
推荐指数
7
解决办法
4万
查看次数

标签 统计

java ×2

java-8 ×2

java-stream ×2

peek ×1