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

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

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

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

并发

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

并行

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

并发与并行详细对比

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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 本系列译自jakob jenkov的Java并发多线程教程(本章节部分内容参考http://ifeve.c...
    Steven_cao阅读 1,006评论 1 10
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 135,083评论 19 139
  • 从三月份找实习到现在,面了一些公司,挂了不少,但最终还是拿到小米、百度、阿里、京东、新浪、CVTE、乐视家的研发岗...
    时芥蓝阅读 42,391评论 11 349
  • 请客提前发菜单请定夺才叫有诚意
    Stan森阅读 225评论 0 0
  • 2017年8月20日 今天是你走后的第100天,我刚刚习惯身旁没有你的感受,可在这个家里,任何的物品都能让我想起你...
    雪迹流殇阅读 1,127评论 7 19