欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  Java

Java 并发对并行的详细介绍

程序员文章站 2022-04-30 14:45:17
...
并行和并发这个条目经常使用在有关于多线程程序中。但是并行和并发确切的含义是什么呢?以及他们是相同的或者什么?

最简单的回答是“不”。他们不是相同的词条,虽然他们在表面上看起来非常相似。它也花费了我一些时间去发现理解他们之间的不同。因此我决定在本教程中添加一篇关于他们的主题。

并发

并发意味着一个应用同时运行不止一个任务。如果计算机只有一个CPU,应用可能同时不会真正的运行超过一个程序,但是在应用的内部每次有不止一个程序被运行了。在它开始下一个之前,它不能完全的结束一个任务。

Java 并发对并行的详细介绍.

并行

并行意味着应用程序把他的任务分成小的子任务,这些子任务可以并行的运行,例如在确定的同时的多个CPU上。

Java 并发对并行的详细介绍

并发和并行的详细比较

正如你看到的,并发是一个应用如何处理多个任务。应用程序可以顺序的执行任务或者并发的同时执行多个任务。

并行换句话说,是关于一个应用如何处理一个单独的任务。应用程序可能从开始到结束连续的执行这个任务,或者分离这个任务为多个子任务可以去并行的运行的。

正如你看到的,一个应用可以是并发的,但是不能并行的。这就意味着它同时执行超过一个任务,但是这个任务不能分离成子任务。

一个应用也可以是并行的而不是并发的。这就意味着这个应用同时执行一个任务,并且这个任务被分离成多个子任务去并行的运行。

另外的,一个应用可以既不是并发的也不是并行的。这就意味着这个应用只是同时工作在一个任务上,并且这个任务不会被分离成子任务。

最后,一个应用既可以是并发也可以是并行的,这样的情况下,它可以同时既工作在多个任务上,也可以把每一个任务分离成多个子任务去并行的执行。然而,在这个场景中并发和并行的一些好处可能会丢失掉,因为在计算机中的CPU对于并发或者并行已经保持相当的繁忙了。他们两个组合使用可能会有一个小的性能提升或者甚至是性能丢失。在你盲目的采用并发并行模型之前,你需要确认分析和衡量好。


以上就是Java 并发对并行的详细介绍的内容,更多相关内容请关注PHP中文网(www.php.cn)!