如果我在 java 8中有并行流,并且我终止了一个anyMatch,并且我的集合有一个与谓词匹配的元素,我试图找出当一个线程处理这个元素时会发生什么.

我知道anyMatch是短路的,所以我不希望在处理匹配元素后再处理更多的元素.我的混淆是关于其他线程发生的事情,大概在处理元素的中间.我可以想到3个合理的场景:
a)他们中断了吗?
b)他们是否继续处理他们正在工作的元素,然后,一旦所有的线程都没有做任何事情,我得到我的结果?
c)我得到我的结果,但正在处理其他元素的线程继续处理这些元素(但是一旦完成,不会占用其他元素)?

我有一个长时间运行的谓词,一旦我知道一个元素匹配,它很快就终止了.我担心一点,因为我在文档中找不到这个信息,它可能是实现依赖的事情,这也是很好的知道.

谢谢

解决方法

经过 Java源代码的挖掘,我觉得我找到了答案.

其他线程会定期检查另一个线程是否找到答案,如果是,则它们停止工作并取消任何尚未运行的节点.

java.util.Stream.FindOps $FindTask有这个方法:

private void foundResult(O answer) {
        if (isLeftmostNode())
            shortCircuit(answer);
        else
            cancelLaterNodes();
    }

它的父类AbstractShortcircuitTask这样实现shortCircuit:

/**
 * Declares that a globally valid result has been found.  If another task has
 * not already found the answer,the result is installed in
 * {@code sharedResult}.  The {@code compute()} method will check
 * {@code sharedResult} before proceeding with computation,so this causes
 * the computation to terminate early.
 *
 * @param result the result found
 */
protected void shortCircuit(R result) {
    if (result != null)
        sharedResult.compareAndSet(null,result);
}

而实际执行的compute()方法有这个重要的一行:

atomicreference<R> sr = sharedResult;
    R result;
    while ((result = sr.get()) == null) {
        ...//does the actual fork stuff here
    }

其中sharedResult由shortCircuit()方法更新,所以计算将在下次检查while循环条件时看到它.

编辑
所以总结一下:

>线程不会中断相反,他们会定期检查是否有人找到答案,如果已经找到答案,将会停止进一步处理.>一旦找到答案,就不会启动新的主题.

java-8 – Java 8并行流anyMatch – 一旦找到匹配,线程会中断?的更多相关文章

  1. 如何在Swift中断后恢复音频?

    我按照指示here,我已经把这个测试项目放在一起来处理音频播放的中断.具体来说,我正在使用默认iphone时钟应用程序中的警报作为中断.似乎中断处理程序被调用,但没有超过let=interruptionType行,因为“错误类型”出现了两次.此外,按照一个想法here,我已经修改了处理程序结果是所有“开始”,“音频暂停”,“结束”和“音频恢复”都显示在控制台中,但音频播放实际上并未恢复.注意:我将

  2. Windows中的中断处理

    我想知道哪些线程处理设备中断.当用户模式线程运行时出现中断时会发生什么?本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  3. ubuntu – 高LOC中断的原因是什么?

    我看到LOC中断出现了巨大的峰值–大约每秒400万,究竟是什么会导致LOC中断,这会导致这些峰值,我该怎么办呢?

  4. 如何将单个换行符作为PHP Markdown中的实线中断处理?

    我正在读http://github.github.com/github-flavored-markdown/我想在PHPMarkdown中实现“Newline修改”:最好我想到的是:但这是非常不可预知的.在您的降价文件中查找行:并将其下面的preg模式从:至:或者你可以扩展markdown类,重新声明’doHardBreaks’功能,并将返回值改为上面的代码问候,Achmad

  5. php – MySQL中“许多连续中断的连接请求”是什么?

    我经常有以下错误:PHP致命错误:带有消息’sqlSTATE[HY000]的未捕获异常’PDOException'[1129]由于许多连接错误,主机’MYSERVER’被阻止;使用’MysqLadminflush-hosts’取消阻止使用常规MysqLadminflush-hosts命令或增加max_connect_errors系统变量很容易解决问题,如here所示.但是!什么是“许多连续中断的连接请求”,为什么会发生这种情况?

  6. Windows Server 2008,一个非常小的DDoS能够杀死我的服务器

    4个所以我有运行WindowsServer2008的i73.2Ghz6核专用服务器,网速为1Gbps.一切都运行良好,机器强大到足以处理甚至高达700Mbps的DoS攻击非常容易..没有滞后,没有问题..有时候我们习惯了大攻击,但一次只有1或2个IP,所以cpu使用率总是很好,直到最近,我们发现了一个全新的DDoS攻击!当我的服务器能够在以前的网络使用率的90%之前保持活力时,他怎么能以4%的网络使用率杀死我的服务器?!

  7. windows-xp – 什么是“中断”过程以及为什么它如此喜欢我的CPU?

    我在IntelCoreDuo2GHz上安装了WindowsXPSP3.根据ProcessExplorer,“Interrupts”进程不断占用30-40%的cpu.这是正常的吗?

  8. windows – 重新安装操作系统时软件raid是否中断?

    重新安装操作系统时,软件raid会中断吗?如果是,有没有办法防止它,或重新安装后没有数据丢失重新创建它?如果不是,那么在做这件事时你有什么需要记住的吗?还是只是自动修复?

  9. 程序集 – 使用自己的键盘中断`int 09h`处理程序时代码的奇怪行为(损坏的绘制)

    替代方案.我确实检查了如何编写DOS键盘处理程序,所以这是我的建议:…然后在游戏代码中,要检查密钥的状态,你也必须使用cs:

  10. ios – AVAudioRecorder在音频会话中断结束后不在后台录制

    int’.错误代码列在AVAudioSession.h文件中:

随机推荐

  1. 基于EJB技术的商务预订系统的开发

    用EJB结构开发的应用程序是可伸缩的、事务型的、多用户安全的。总的来说,EJB是一个组件事务监控的标准服务器端的组件模型。基于EJB技术的系统结构模型EJB结构是一个服务端组件结构,是一个层次性结构,其结构模型如图1所示。图2:商务预订系统的构架EntityBean是为了现实世界的对象建造的模型,这些对象通常是数据库的一些持久记录。

  2. Java利用POI实现导入导出Excel表格

    这篇文章主要为大家详细介绍了Java利用POI实现导入导出Excel表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. Mybatis分页插件PageHelper手写实现示例

    这篇文章主要为大家介绍了Mybatis分页插件PageHelper手写实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  4. (jsp/html)网页上嵌入播放器(常用播放器代码整理)

    网页上嵌入播放器,只要在HTML上添加以上代码就OK了,下面整理了一些常用的播放器代码,总有一款适合你,感兴趣的朋友可以参考下哈,希望对你有所帮助

  5. Java 阻塞队列BlockingQueue详解

    本文详细介绍了BlockingQueue家庭中的所有成员,包括他们各自的功能以及常见使用场景,通过实例代码介绍了Java 阻塞队列BlockingQueue的相关知识,需要的朋友可以参考下

  6. Java异常Exception详细讲解

    异常就是不正常,比如当我们身体出现了异常我们会根据身体情况选择喝开水、吃药、看病、等 异常处理方法。 java异常处理机制是我们java语言使用异常处理机制为程序提供了错误处理的能力,程序出现的错误,程序可以安全的退出,以保证程序正常的运行等

  7. Java Bean 作用域及它的几种类型介绍

    这篇文章主要介绍了Java Bean作用域及它的几种类型介绍,Spring框架作为一个管理Bean的IoC容器,那么Bean自然是Spring中的重要资源了,那Bean的作用域又是什么,接下来我们一起进入文章详细学习吧

  8. 面试突击之跨域问题的解决方案详解

    跨域问题本质是浏览器的一种保护机制,它的初衷是为了保证用户的安全,防止恶意网站窃取数据。那怎么解决这个问题呢?接下来我们一起来看

  9. Mybatis-Plus接口BaseMapper与Services使用详解

    这篇文章主要为大家介绍了Mybatis-Plus接口BaseMapper与Services使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  10. mybatis-plus雪花算法增强idworker的实现

    今天聊聊在mybatis-plus中引入分布式ID生成框架idworker,进一步增强实现生成分布式唯一ID,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部