美文网首页Java 并发/多线程
Java 并发/多线程教程(六)-并发VS并行

Java 并发/多线程教程(六)-并发VS并行

作者: Steven_cao | 来源:发表于2017-05-05 00:04 被阅读126次

       本系列译自jakob jenkov的Java并发多线程教程,个人觉得很有收获。由于个人水平有限,不对之处还望矫正!

        在多线程线程编程中,我们经常提及并发和并行,但是并发和并行究竟是什么意思,他们所要表达是同一回事,还是不是同一加事。

       它们当然不是一回事,虽然表面上它们看起来非常的相似,但是它们是两个不相同的术语。在此之前,我也花费了大量的时间去了解并发与并行的区别,因此我觉得在这里对比一下两者。

并发

        并发意味着一个应用在同一时刻处理多个任务。如果计算机只有一个CPU,那么应用程序不可能在同一时刻处理多个任务,但在应用内部,会有多个任务被处理,也就是说一个任务还没有结束的时候另一个任务已经开始被处理。

并行

         并行意味着应用将任务划分成多个小的子任务,去并行的执行。

并发与并行详细对比

        正如你所看到的一样。并发与应用程序如何处理多任务有关,应用程序可以在同一时刻处理一个任务(顺序),也有可能在同一时刻处理多个任务(并发)。并行,换句话来说就是,它与应用程序如何处理每个单独的任务有关。应用程序可以从开始到结束连续处理,或是将任务划分解成多个可以并行运行的子任务。如你所看到的,有些应用程序可以是并发但不是并行的,这就是说同一时刻可以处理多个任务,而这些任务不会分解成多个子任务。应用程序可以是并行的但不是并发的,这就是说同一时刻只有一个任务在执行,任务被分解成多个子任务并行执行。除此,一个应用程序可以既不是并行的,也不不并发的,这就是说,同一时刻只有一个任务执行,而且这个任务绝对不会拆解成多个子任务去并行执行。最后,一个应用程序可以是并行的也可以是并发的,这就是说同一时刻可以有多个任务并发执行,同时每个任务又可以拆解成多个子任务并行的去执行。然而,在这种情况下,并发和并行的优点可能不复存在,因为计算机中CPU已经很繁忙的去处理并发和并行,他们二者的结合可能只会产生较小的性能提升或者甚至降低。因此在选择并发并行模型时,请确保你的分析和度量。

相关文章

  • Java 并发/多线程教程(六)-并发VS并行

    本系列译自jakob jenkov的Java并发多线程教程,个人觉得很有收获。由于个人水平有限,不对之处还望...

  • 一. Java并发和多线程简介

    Java并发是一个涉及了java平台上多线程(MultiTheadings)、并发(Concurrency)和并行...

  • Tutorial

    Java Concurrency涵盖了Java平台上的多线程、并发性和并行性。这包括Java并发工具、问题以及解决...

  • java面试题(三)

    Java 多线程模块 1、并行和并发有什么区别? 并行:多个处理器或多核处理器同时处理多个任务。 并发:多个任务在...

  • 多线程

    并发 && 并行 多线程的同时执行并非"并行", 而是"并发", "并发"无论从宏观还是微观上都是同时执行的, 而...

  • Java面试题(二):多线程

    五、多线程 35. 并行和并发有什么区别? 并发(concurrency)和并行(parallellism)是: ...

  • Java并发教程

    Java并发教程 Java并发概述Java并发环境设置Java并发主要操作Java并发性线程间通信Java并发同步...

  • Golang学习笔记-Goroutines

    并发 首先 go 是一个实现并发的语言,并非并行 并发 vs 并行 并行是在同一时间内,可以同时执行多个任务;并发...

  • Java并发编程整理之并发与并行概念讲解(1)

    Java并发编程整理之并发与并行概念讲解(1) 并发和并行区别 --[百度]:并发(Concurrent)当有多个...

  • 多线程并发 (五) ReentrantLock 使用和源码

    章节: 多线程并发 (一) 了解 Java 虚拟机 - JVM 多线程并发 (二) 了解 Thread 多线程并发...

网友评论

    本文标题:Java 并发/多线程教程(六)-并发VS并行

    本文链接:https://www.haomeiwen.com/subject/faqjtxtx.html